Skip to content

Commit

Permalink
Merge branch 'red-hat-data-services:master' into master
Browse files Browse the repository at this point in the history
  • Loading branch information
tarukumar authored Dec 14, 2023
2 parents 5037e7d + ac355c4 commit 51b27ad
Show file tree
Hide file tree
Showing 19 changed files with 196 additions and 44 deletions.
6 changes: 6 additions & 0 deletions ods_ci/libs/DataSciencePipelinesAPI.py
Original file line number Diff line number Diff line change
Expand Up @@ -310,6 +310,12 @@ def get_default_storage(self):
break
return storage_class['metadata']['name']

def get_openshift_server(self):
return self.run_oc('oc whoami --show-server=true')[0].replace('\n', '')

def get_openshift_token(self):
return self.run_oc('oc whoami --show-token=true')[0].replace('\n', '')

def run_oc(self, command):
process = subprocess.Popen(command.split(), stdout=subprocess.PIPE)
output, error = process.communicate()
Expand Down
4 changes: 3 additions & 1 deletion ods_ci/libs/DataSciencePipelinesKfpTekton.py
Original file line number Diff line number Diff line change
Expand Up @@ -111,7 +111,9 @@ def kfp_tekton_create_run_from_pipeline_func(
result = client.create_run_from_pipeline_func(
pipeline_func=pipeline, arguments={
'mlpipeline_minio_artifact_secret': mlpipeline_minio_artifact_secret["data"],
'bucket_name': bucket_name
'bucket_name': bucket_name,
'openshift_server': self.api.get_openshift_server(),
'openshift_token': self.api.get_openshift_token()
}
)
# easy to debug and double check failures
Expand Down
2 changes: 1 addition & 1 deletion ods_ci/tasks/Resources/RHODS_OLM/install/oc_install.robot
Original file line number Diff line number Diff line change
Expand Up @@ -306,7 +306,7 @@ Install Kserve Dependencies
... catalog_source_name=redhat-operators
... operator_group_name=serverless-operators
... operator_group_ns=${SERVERLESS_NS}
... operator_group_target_ns=${NONE}}
... operator_group_target_ns=${NONE}
Wait For Pods To Be Ready label_selector=name=knative-openshift
... namespace=${SERVERLESS_NS}
Wait For Pods To Be Ready label_selector=name=knative-openshift-ingress
Expand Down
4 changes: 2 additions & 2 deletions ods_ci/tests/Resources/Files/AppsInfoDictionary_latest.json
Original file line number Diff line number Diff line change
Expand Up @@ -111,7 +111,7 @@
"matching": "full"
},
"1": {
"text": "Adding users for OpenShift Data Science",
"text": "Adding users for Red Hat OpenShift AI",
"url": "https://access.redhat.com/documentation/en-us/red_hat_openshift_data_science/1/html/managing_users_and_user_resources/adding-users-for-openshift-data-science_useradd",
"matching": "full"
}
Expand Down Expand Up @@ -275,7 +275,7 @@
],
"provider": "by Starburst",
"title": "Starburst Enterprise",
"description": "Starburst Enterprise platform (SEP) is the commericial distribution of Trino, which is an open-source, Massively Parallel Processing (MPP) ANSI SQL query engine. Starburst simplifies data access for your RHODS workloads by providing fast access to all of your data, no matter where it lives. Starburst does this by connecting directly to each data source and pulling the data back into memory for processing, alleviating the need to copy or move the data into a single location first.",
"description": "Starburst Enterprise platform (SEP) is the commericial distribution of Trino, which is an open-source, Massively Parallel Processing (MPP) ANSI SQL query engine. Starburst simplifies data access for your Red Hat OpenShift AI workloads by providing fast access to all of your data, no matter where it lives. Starburst does this by connecting directly to each data source and pulling the data back into memory for processing, alleviating the need to copy or move the data into a single location first.",
"rhods_type": ["Self-managed"],
"image": "",
"sidebar_h1": "Starburst Enterprise",
Expand Down
88 changes: 88 additions & 0 deletions ods_ci/tests/Resources/Files/pipeline-samples/ray_integration.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,88 @@
from kfp import components, dsl
from ods_ci.libs.DataSciencePipelinesKfpTekton import DataSciencePipelinesKfpTekton


def ray_fn(openshift_server:str, openshift_token:str) -> int:
from codeflare_sdk.cluster.cluster import Cluster, ClusterConfiguration
from codeflare_sdk.cluster.auth import TokenAuthentication
import ray

print('before login')
auth = TokenAuthentication(
token=openshift_token,
server=openshift_server,
skip_tls=True
)
auth_return = auth.login()
print(f'auth_return: "{auth_return}"')
print('after login')
cluster = Cluster(ClusterConfiguration(
name='raytest',
# namespace must exist, and it is the same from 432__data-science-pipelines-tekton.robot
namespace='pipelineskfptekton1',
num_workers=1,
head_cpus='500m',
min_memory=1,
max_memory=1,
num_gpus=0,
image="quay.io/project-codeflare/ray:latest-py39-cu118",
instascale=False
))
# workaround for https://github.com/project-codeflare/codeflare-sdk/pull/412
cluster_file_name = '/opt/app-root/src/.codeflare/appwrapper/raytest.yaml'
# Read in the file
with open(cluster_file_name, 'r') as file:
filedata = file.read()

# Replace the target string
filedata = filedata.replace('busybox:1.28', 'quay.io/project-codeflare/busybox:latest')

# Write the file out again
with open(cluster_file_name, 'w') as file:
file.write(filedata)
# end workaround

# always clean the resources
cluster.down()
print(cluster.status())
cluster.up()
cluster.wait_ready()
print(cluster.status())
print(cluster.details())

ray_dashboard_uri = cluster.cluster_dashboard_uri()
ray_cluster_uri = cluster.cluster_uri()
print(ray_dashboard_uri)
print(ray_cluster_uri)

# before proceeding make sure the cluster exists and the uri is not empty
assert ray_cluster_uri, "Ray cluster needs to be started and set before proceeding"

# reset the ray context in case there's already one.
ray.shutdown()
# establish connection to ray cluster
ray.init(address=ray_cluster_uri)
print("Ray cluster is up and running: ", ray.is_initialized())

@ray.remote
def train_fn():
return 100

result = ray.get(train_fn.remote())
assert 100 == result
ray.shutdown()
cluster.down()
auth.logout()
return result


@dsl.pipeline(
name="Ray Integration Test",
description="Ray Integration Test",
)
def ray_integration(openshift_server, openshift_token):
ray_op = components.create_component_from_func(
ray_fn, base_image=DataSciencePipelinesKfpTekton.base_image,
packages_to_install=['codeflare-sdk']
)
ray_op(openshift_server, openshift_token)
8 changes: 6 additions & 2 deletions ods_ci/tests/Resources/OCP.resource
Original file line number Diff line number Diff line change
Expand Up @@ -138,6 +138,10 @@ Get Pod Hardware Resources And Limits
RETURN ${resources}

Container Hardware Resources Should Match Expected
[Documentation] This keyword checks that the requests/limits set in a specific container in a pod contain the
... requests and limits passed in with `exp_requests` and `exp_limits`. This means that the container might have
... additional requests/limits set which are not explicitly checked against. If you want to make sure you're
... checking all attributes you have to explicitly pass them in with `exp_requests/limits`.
[Arguments] ${container_name} ${pod_label_selector} ${namespace}
... ${exp_requests}=${NONE} ${exp_limits}=${NONE}
${resources_dict}= Get Pod Hardware Resources And Limits label_selector=${pod_label_selector}
Expand All @@ -146,15 +150,15 @@ Container Hardware Resources Should Match Expected
Dictionary Should Not Contain Key ${resources_dict} requests
ELSE
${requests}= Set Variable ${resources_dict}[requests]
FOR ${index} ${resource} IN ENUMERATE @{requests.keys()}
FOR ${index} ${resource} IN ENUMERATE @{exp_requests.keys()}
Should Be Equal As Strings ${requests}[${resource}] ${exp_requests}[${resource}]
END
END
IF ${exp_limits} == ${NONE}
Dictionary Should Not Contain Key ${resources_dict} limits
ELSE
${limits}= Set Variable ${resources_dict}[limits]
FOR ${index} ${resource} IN ENUMERATE @{limits.keys()}
FOR ${index} ${resource} IN ENUMERATE @{exp_limits.keys()}
Should Be Equal As Strings ${limits}[${resource}] ${exp_limits}[${resource}]
END
END
Expand Down
6 changes: 3 additions & 3 deletions ods_ci/tests/Resources/ODS.robot
Original file line number Diff line number Diff line change
Expand Up @@ -62,20 +62,20 @@ Get "Usage Data Collection" Key

Is Usage Data Collection Enabled
[Documentation] Returns a boolean with the value of configmap odh-segment-key-config > segmentKeyEnabled
... which can be seen also in ODS Dashboard > Cluster Settings > "Usage Data Collection"
... which can be seen also in ODS Dashboard > Cluster settings > "Usage Data Collection"
${usage_data_collection_enabled}= Run
... oc get configmap odh-segment-key-config -n ${APPLICATIONS_NAMESPACE} -o jsonpath='{.data.segmentKeyEnabled}'
${usage_data_collection_enabled}= Convert To Boolean ${usage_data_collection_enabled}
RETURN ${usage_data_collection_enabled}

Usage Data Collection Should Be Enabled
[Documentation] Fails if "Usage Data Collection" is not enabled in ODS Dashboard > Cluster Settings
[Documentation] Fails if "Usage Data Collection" is not enabled in ODS Dashboard > Cluster settings
[Arguments] ${msg}="Usage Data Collection" should be enabled
${enabled}= ODS.Is Usage Data Collection Enabled
Should Be True ${enabled} msg=${msg}

Usage Data Collection Should Not Be Enabled
[Documentation] Fails if "Usage Data Collection" is enabled in ODS Dashboard > Cluster Settings
[Documentation] Fails if "Usage Data Collection" is enabled in ODS Dashboard > Cluster settings
[Arguments] ${msg}="Usage Data Collection" should not be enabled
${enabled}= ODS.Is Usage Data Collection Enabled
Should Not Be True ${enabled} msg=${msg}
Expand Down
Loading

0 comments on commit 51b27ad

Please sign in to comment.