Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Create POC of Fix dev spaces devfile api tests to avoid using an absolute devfile registry for PHP stack #23200

Conversation

musienko-maxim
Copy link
Contributor

@musienko-maxim musienko-maxim commented Oct 21, 2024

What does this PR do?

This PR provides an alternative solution for API tests using our CHE test codebase:

  • After investigations the most reliable way for airgap and online clusters - using the DEvFile generator + oc apply approach
  • For getting sources of Devfile and Che editor - the most reliable way - extract it from the test-cluster using CHE-config map for editor and the internal cluster dashboard cluster Service (which includes a simple web server and we can obtain devfile using HTTP responses)

Screenshot/screencast of this PR

/usr/bin/npm run driver-less-test

> @eclipse-che/[email protected] driver-less-test
> export TS_USE_WEB_DRIVER_FOR_TEST=false && npm run test

> @eclipse-che/[email protected] test
> ./configs/sh-scripts/initDefaultValues.sh npm run lint && npm run tsc && export USERSTORY=$USERSTORY && mocha --config dist/configs/mocharc.js

Initialized default values

TS_SELENIUM_VALUE_TLS_SUPPORT =       
TS_SELENIUM_VALUE_OPENSHIFT_OAUTH =   false
TS_OCP_LOGIN_PAGE_PROVIDER_TITLE =    htpasswd
E2E_OCP_CLUSTER_VERSION =             4.x
TS_SELENIUM_LOG_LEVEL =               DEBUG
TS_SELENIUM_OCP_USERNAME =            admin
TS_SELENIUM_W3C_CHROME_OPTION =       true
NODE_TLS_REJECT_UNAUTHORIZED =        0
TS_SELENIUM_EDITOR =                  che-code

> @eclipse-che/[email protected] tsc
> rm -rf ./dist && ./configs/sh-scripts/generateIndex.sh && tsc -p .

Generating index.ts file...
Warning: Cannot find any files matching pattern "dist/specs/PhpDevFileAPI.spec.js"

################## Launch Information ##################

      TS_SELENIUM_BASE_URL: https://devspaces.apps.ocp417-mmusiie.crw-qe.com
      TS_SELENIUM_HEADLESS: false
      TS_SELENIUM_OCP_USERNAME: admin
      TS_SELENIUM_EDITOR:   che-code

      TS_SELENIUM_HAPPY_PATH_WORKSPACE_NAME: EmptyWorkspace
      TS_SELENIUM_DELAY_BETWEEN_SCREENSHOTS: 1000
      TS_SELENIUM_REPORT_FOLDER: ./report
      TS_SELENIUM_EXECUTION_SCREENCAST: false
      DELETE_SCREENCAST_IF_TEST_PASS: true
      TS_SELENIUM_REMOTE_DRIVER_URL: 
      DELETE_WORKSPACE_ON_FAILED_TEST: false
      TS_SELENIUM_LOG_LEVEL: TRACE
      TS_SELENIUM_LAUNCH_FULLSCREEN: true

      

      TS_COMMON_DASHBOARD_WAIT_TIMEOUT: 5000
      TS_SELENIUM_START_WORKSPACE_TIMEOUT: 360000
      TS_WAIT_LOADER_PRESENCE_TIMEOUT: 60000

      TS_SAMPLE_LIST: Node.js MongoDB,Node.js Express,Java Lombok,Quarkus REST API,Python,.NET,C/C++,Go,PHP,Ansible

      MOCHA_DIRECTORY is not set
      USERSTORY: PhpDevFileAPI

      to output timeout variables, set TS_SELENIUM_PRINT_TIMEOUT_VARIABLES to true
 ######################################################## 


            ‣ DriverHelper.getDriver
  Ansible devfile API test
          ▼ KubernetesCommandLineToolsExecutor.loginToOcp - oc - login to the "OC" client.
          ▼ KubernetesCommandLineToolsExecutor.getServerUrl - oc - get server api url.
          ▼ KubernetesCommandLineToolsExecutor.isUserLoggedIn - oc
          ▼ ShellExecutor.executeCommand - oc whoami && oc whoami --show-server=true
admin
https://api.ocp417-mmusiie.crw-qe.com:6443
          ▼ KubernetesCommandLineToolsExecutor.getServerUrl - oc - get server api url.
          ▼ KubernetesCommandLineToolsExecutor.loginToOcp - oc - user already logged
          ▼ ShellExecutor.executeArbitraryShellScript - oc get pods -n openshift-devspaces | grep dashboard | awk '{print $1}'
          ▼ ShellExecutor.executeCommand - oc get pods -n openshift-devspaces | grep dashboard | awk '{print $1}'
devspaces-dashboard-744764799d-nq6t7
          ▼ ShellExecutor.executeArbitraryShellScript - oc get pod -n openshift-devspaces devspaces-dashboard-744764799d-nq6t7 -o jsonpath='{.spec.containers[*].name}'
          ▼ ShellExecutor.executeCommand - oc get pod -n openshift-devspaces devspaces-dashboard-744764799d-nq6t7 -o jsonpath='{.spec.containers[*].name}'
devspaces-dashboard          ▼ ShellExecutor.executeArbitraryShellScript - oc get svc devspaces-dashboard -n openshift-devspaces -o=jsonpath='{.spec.clusterIP}'
          ▼ ShellExecutor.executeCommand - oc get svc devspaces-dashboard -n openshift-devspaces -o=jsonpath='{.spec.clusterIP}'
172.30.145.32          ▼ ShellExecutor.executeArbitraryShellScript - oc get svc devspaces-dashboard -n openshift-devspaces -o=jsonpath='{.spec.ports[*].port}'
          ▼ ShellExecutor.executeCommand - oc get svc devspaces-dashboard -n openshift-devspaces -o=jsonpath='{.spec.ports[*].port}'
8080          ▼ ShellExecutor.executeCommand - oc exec -i devspaces-dashboard-744764799d-nq6t7 -n openshift-devspaces -c devspaces-dashboard -- sh -c 'curl -o /tmp/php-devfile.yaml http://172.30.145.32:8080/dashboard/api/airgap-sample/devfile/download?id=php'
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100   698  100   698    0     0   340k      0 --:--:-- --:--:-- --:--:--  340k
          ▼ ShellExecutor.executeArbitraryShellScript - oc exec -i devspaces-dashboard-744764799d-nq6t7 -n openshift-devspaces -c devspaces-dashboard -- cat /tmp/php-devfile.yaml
          ▼ ShellExecutor.executeCommand - oc exec -i devspaces-dashboard-744764799d-nq6t7 -n openshift-devspaces -c devspaces-dashboard -- cat /tmp/php-devfile.yaml
schemaVersion: 2.2.2
metadata:
  name: php-hello-world
components:
  - name: tools
    container:
      image: registry.redhat.io/devspaces/udi-rhel8@sha256:ef47509acf12ca5660aaee1099cb4b3de97cc4cb8b2e256020e6df72c7720197
      memoryLimit: '2Gi'
      memoryRequest: '1Gi'
      cpuLimit: '1'
      cpuRequest: '0.5'
commands:
  - id: run
    exec:
      label: "Run the application"
      component: tools
      workingDir: ${PROJECTS_ROOT}/php-hello-world
      commandLine: php hello-world.php
      group:
        kind: run
projects:
  - name: php-hello-world
    zip:
      location: http://devspaces-dashboard.openshift-devspaces.svc:8080/dashboard/api/airgap-sample/project/download?id=php
          ▼ ShellExecutor.executeCommand - oc get configmap editors-definitions -o jsonpath="{.data.che-code\.yaml}" -n openshift-devspaces
commands:
- apply:
    component: che-code-injector
  id: init-container-command
- exec:
    commandLine: nohup /checode/entrypoint-volume.sh > /checode/entrypoint-logs.txt
      2>&1 &
    component: che-code-runtime-description
  id: init-che-code-command
components:
- container:
    command:
    - /entrypoint-init-container.sh
    cpuLimit: 500m
    cpuRequest: 30m
    image: registry.redhat.io/devspaces/code-rhel8@sha256:96766cc129ac26ae59f046c75a875ab234f7bfeee4778369422ace622872c555
    memoryLimit: 256Mi
    memoryRequest: 32Mi
    volumeMounts:
    - name: checode
      path: /checode
  name: che-code-injector
- attributes:
    app.kubernetes.io/component: che-code-runtime
    app.kubernetes.io/part-of: che-code.eclipse.org
    controller.devfile.io/container-contribution: true
  container:
    cpuLimit: 500m
    cpuRequest: 30m
    endpoints:
    - attributes:
        cookiesAuthEnabled: true
        discoverable: false
        type: main
        urlRewriteSupported: true
      exposure: public
      name: che-code
      protocol: https
      secure: true
      targetPort: 3100
    - attributes:
        discoverable: false
        urlRewriteSupported: false
      exposure: public
      name: code-redirect-1
      protocol: https
      targetPort: 13131
    - attributes:
        discoverable: false
        urlRewriteSupported: false
      exposure: public
      name: code-redirect-2
      protocol: https
      targetPort: 13132
    - attributes:
        discoverable: false
        urlRewriteSupported: false
      exposure: public
      name: code-redirect-3
      protocol: https
      targetPort: 13133
    image: registry.redhat.io/devspaces/udi-rhel8@sha256:ef47509acf12ca5660aaee1099cb4b3de97cc4cb8b2e256020e6df72c7720197
    memoryLimit: 1024Mi
    memoryRequest: 256Mi
    volumeMounts:
    - name: checode
      path: /checode
  name: che-code-runtime-description
- name: checode
  volume: {}
events:
  postStart:
  - init-che-code-command
  preStart:
  - init-container-command
metadata:
  attributes:
    firstPublicationDate: "2022-07-19"
    iconData: |
      <svg width="100" height="100" viewBox="0 0 100 100" fill="none" xmlns="http://www.w3.org/2000/svg">
      <mask id="mask0" mask-type="alpha" maskUnits="userSpaceOnUse" x="0" y="0" width="100" height="100">
      <path fill-rule="evenodd" clip-rule="evenodd" d="M70.9119 99.3171C72.4869 99.9307 74.2828 99.8914 75.8725 99.1264L96.4608 89.2197C98.6242 88.1787 100 85.9892 100 83.5872V16.4133C100 14.0113 98.6243 11.8218 96.4609 10.7808L75.8725 0.873756C73.7862 -0.130129 71.3446 0.11576 69.5135 1.44695C69.252 1.63711 69.0028 1.84943 68.769 2.08341L29.3551 38.0415L12.1872 25.0096C10.589 23.7965 8.35363 23.8959 6.86933 25.2461L1.36303 30.2549C-0.452552 31.9064 -0.454633 34.7627 1.35853 36.417L16.2471 50.0001L1.35853 63.5832C-0.454633 65.2374 -0.452552 68.0938 1.36303 69.7453L6.86933 74.7541C8.35363 76.1043 10.589 76.2037 12.1872 74.9905L29.3551 61.9587L68.769 97.9167C69.3925 98.5406 70.1246 99.0104 70.9119 99.3171ZM75.0152 27.2989L45.1091 50.0001L75.0152 72.7012V27.2989Z" fill="white"/>
      </mask>
      <g mask="url(#mask0)">
      <path d="M96.4614 10.7962L75.8569 0.875542C73.4719 -0.272773 70.6217 0.211611 68.75 2.08333L1.29858 63.5832C-0.515693 65.2373 -0.513607 68.0937 1.30308 69.7452L6.81272 74.754C8.29793 76.1042 10.5347 76.2036 12.1338 74.9905L93.3609 13.3699C96.086 11.3026 100 13.2462 100 16.6667V16.4275C100 14.0265 98.6246 11.8378 96.4614 10.7962Z" fill="#0065A9"/>
      <g filter="url(#filter0_d)">
      <path d="M96.4614 89.2038L75.8569 99.1245C73.4719 100.273 70.6217 99.7884 68.75 97.9167L1.29858 36.4169C-0.515693 34.7627 -0.513607 31.9063 1.30308 30.2548L6.81272 25.246C8.29793 23.8958 10.5347 23.7964 12.1338 25.0095L93.3609 86.6301C96.086 88.6974 100 86.7538 100 83.3334V83.5726C100 85.9735 98.6246 88.1622 96.4614 89.2038Z" fill="#007ACC"/>
      </g>
      <g filter="url(#filter1_d)">
      <path d="M75.8578 99.1263C73.4721 100.274 70.6219 99.7885 68.75 97.9166C71.0564 100.223 75 98.5895 75 95.3278V4.67213C75 1.41039 71.0564 -0.223106 68.75 2.08329C70.6219 0.211402 73.4721 -0.273666 75.8578 0.873633L96.4587 10.7807C98.6234 11.8217 100 14.0112 100 16.4132V83.5871C100 85.9891 98.6234 88.1786 96.4586 89.2196L75.8578 99.1263Z" fill="#1F9CF0"/>
      </g>
      <g style="mix-blend-mode:overlay" opacity="0.25">
      <path fill-rule="evenodd" clip-rule="evenodd" d="M70.8511 99.3171C72.4261 99.9306 74.2221 99.8913 75.8117 99.1264L96.4 89.2197C98.5634 88.1787 99.9392 85.9892 99.9392 83.5871V16.4133C99.9392 14.0112 98.5635 11.8217 96.4001 10.7807L75.8117 0.873695C73.7255 -0.13019 71.2838 0.115699 69.4527 1.44688C69.1912 1.63705 68.942 1.84937 68.7082 2.08335L29.2943 38.0414L12.1264 25.0096C10.5283 23.7964 8.29285 23.8959 6.80855 25.246L1.30225 30.2548C-0.513334 31.9064 -0.515415 34.7627 1.29775 36.4169L16.1863 50L1.29775 63.5832C-0.515415 65.2374 -0.513334 68.0937 1.30225 69.7452L6.80855 74.754C8.29285 76.1042 10.5283 76.2036 12.1264 74.9905L29.2943 61.9586L68.7082 97.9167C69.3317 98.5405 70.0638 99.0104 70.8511 99.3171ZM74.9544 27.2989L45.0483 50L74.9544 72.7012V27.2989Z" fill="url(#paint0_linear)"/>
      </g>
      </g>
      <defs>
      <filter id="filter0_d" x="-8.39411" y="15.8291" width="116.727" height="92.2456" filterUnits="userSpaceOnUse" color-interpolation-filters="sRGB">
      <feFlood flood-opacity="0" result="BackgroundImageFix"/>
      <feColorMatrix in="SourceAlpha" type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0"/>
      <feOffset/>
      <feGaussianBlur stdDeviation="4.16667"/>
      <feColorMatrix type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.25 0"/>
      <feBlend mode="overlay" in2="BackgroundImageFix" result="effect1_dropShadow"/>
      <feBlend mode="normal" in="SourceGraphic" in2="effect1_dropShadow" result="shape"/>
      </filter>
      <filter id="filter1_d" x="60.4167" y="-8.07558" width="47.9167" height="116.151" filterUnits="userSpaceOnUse" color-interpolation-filters="sRGB">
      <feFlood flood-opacity="0" result="BackgroundImageFix"/>
      <feColorMatrix in="SourceAlpha" type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0"/>
      <feOffset/>
      <feGaussianBlur stdDeviation="4.16667"/>
      <feColorMatrix type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.25 0"/>
      <feBlend mode="overlay" in2="BackgroundImageFix" result="effect1_dropShadow"/>
      <feBlend mode="normal" in="SourceGraphic" in2="effect1_dropShadow" result="shape"/>
      </filter>
      <linearGradient id="paint0_linear" x1="49.9392" y1="0.257812" x2="49.9392" y2="99.7423" gradientUnits="userSpaceOnUse">
      <stop stop-color="white"/>
      <stop offset="1" stop-color="white" stop-opacity="0"/>
      </linearGradient>
      </defs>
      </svg>
    iconMediatype: image/svg+xml
    publisher: che-incubator
    repository: https://github.com/che-incubator/che-code
    skipMetaYaml: true
    title: Red Hat OpenShift Dev Spaces with Microsoft Visual Studio Code - Open Source
      IDE
    version: latest
  description: Red Hat OpenShift Dev Spaces with Microsoft Visual Studio Code - Open
    Source IDE
  displayName: VS Code - Open Source
  name: che-code
schemaVersion: 2.2.2
          ▼ DevWorkspaceConfigurationHelper.generateDevfileContext
No plug-in registry url. Setting to https://eclipse-che.github.io/che-plugin-registry/main/v3
Validating devfile
Devfile is valid with schema version 2.2.2
DevWorkspace che-code-php-hello-world was generated
          ▼ DevWorkspaceConfigurationHelper.getDevWorkspaceConfigurationYamlAsString
          ▼ KubernetesCommandLineToolsExecutor.applyAndWaitDevWorkspace - oc
          ▼ KubernetesCommandLineToolsExecutor.applyYamlConfigurationAsStringOutput - oc
          ▼ ShellExecutor.executeCommand - cat <<EOF | oc apply -n admin-devspaces -f - 
          apiVersion: workspace.devfile.io/v1alpha2
          kind: DevWorkspaceTemplate
          metadata:
            name: che-code-php-hello-world
          spec:
            commands:
              - apply:
                  component: che-code-injector
                id: init-container-command
              - exec:
                  commandLine: nohup /checode/entrypoint-volume.sh > /checode/entrypoint-logs.txt
                    2>&1 &
                  component: che-code-runtime-description
                id: init-che-code-command
            components:
              - container:
                  command:
                    - /entrypoint-init-container.sh
                  cpuLimit: 500m
                  cpuRequest: 30m
                  image: registry.redhat.io/devspaces/code-rhel8@sha256:96766cc129ac26ae59f046c75a875ab234f7bfeee4778369422ace622872c555
                  memoryLimit: 256Mi
                  memoryRequest: 32Mi
                  volumeMounts:
                    - name: checode
                      path: /checode
                name: che-code-injector
              - attributes:
                  app.kubernetes.io/component: che-code-runtime
                  app.kubernetes.io/part-of: che-code.eclipse.org
                  controller.devfile.io/container-contribution: true
                container:
                  cpuLimit: 500m
                  cpuRequest: 30m
                  endpoints:
                    - attributes:
                        cookiesAuthEnabled: true
                        discoverable: false
                        type: main
                        urlRewriteSupported: true
                      exposure: public
                      name: che-code
                      protocol: https
                      secure: true
                      targetPort: 3100
                    - attributes:
                        discoverable: false
                        urlRewriteSupported: false
                      exposure: public
                      name: code-redirect-1
                      protocol: https
                      targetPort: 13131
                    - attributes:
                        discoverable: false
                        urlRewriteSupported: false
                      exposure: public
                      name: code-redirect-2
                      protocol: https
                      targetPort: 13132
                    - attributes:
                        discoverable: false
                        urlRewriteSupported: false
                      exposure: public
                      name: code-redirect-3
                      protocol: https
                      targetPort: 13133
                  image: registry.redhat.io/devspaces/udi-rhel8@sha256:ef47509acf12ca5660aaee1099cb4b3de97cc4cb8b2e256020e6df72c7720197
                  memoryLimit: 1024Mi
                  memoryRequest: 256Mi
                  volumeMounts:
                    - name: checode
                      path: /checode
                name: che-code-runtime-description
              - name: checode
                volume: {}
            events:
              postStart:
                - init-che-code-command
              preStart:
                - init-container-command
          ---
          apiVersion: workspace.devfile.io/v1alpha2
          kind: DevWorkspace
          metadata:
            name: php-hello-world
            annotations:
              che.eclipse.org/devfile: >
                schemaVersion: 2.2.2
          
                metadata:
                  name: php-hello-world
                components:
                  - name: tools
                    container:
                      image: >-
                        registry.redhat.io/devspaces/udi-rhel8@sha256:ef47509acf12ca5660aaee1099cb4b3de97cc4cb8b2e256020e6df72c7720197
                      memoryLimit: 2Gi
                      memoryRequest: 1Gi
                      cpuLimit: '1'
                      cpuRequest: '0.5'
                commands:
                  - id: run
                    exec:
                      label: Run the application
                      component: tools
                      workingDir: ${PROJECTS_ROOT}/php-hello-world
                      commandLine: php hello-world.php
                      group:
                        kind: run
                projects:
                  - name: php-hello-world
                    zip:
                      location: >-
                        http://devspaces-dashboard.openshift-devspaces.svc:8080/dashboard/api/airgap-sample/project/download?id=php
          spec:
            started: true
            routingClass: che
            template:
              components:
                - name: tools
                  container:
                    image: registry.redhat.io/devspaces/udi-rhel8@sha256:ef47509acf12ca5660aaee1099cb4b3de97cc4cb8b2e256020e6df72c7720197
                    memoryLimit: 2Gi
                    memoryRequest: 1Gi
                    cpuLimit: "1"
                    cpuRequest: "0.5"
              commands:
                - id: run
                  exec:
                    label: Run the application
                    component: tools
                    workingDir: ${PROJECTS_ROOT}/php-hello-world
                    commandLine: php hello-world.php
                    group:
                      kind: run
              projects:
                - name: php-hello-world
                  zip:
                    location: http://devspaces-dashboard.openshift-devspaces.svc:8080/dashboard/api/airgap-sample/project/download?id=php
            contributions:
              - name: editor
                kubernetes:
                  name: che-code-php-hello-world
          
          EOF
devworkspacetemplate.workspace.devfile.io/che-code-php-hello-world created
devworkspace.workspace.devfile.io/php-hello-world created
          ▼ KubernetesCommandLineToolsExecutor.waitDevWorkspace - oc - wait till workspace ready.
          ▼ ShellExecutor.executeCommand - oc wait -n admin-devspaces --for=condition=Ready dw php-hello-world --timeout=360s
devworkspace.workspace.devfile.io/php-hello-world condition met
          ▼ KubernetesCommandLineToolsExecutor.getPodAndContainerNames - oc
          ▼ KubernetesCommandLineToolsExecutor.getWorkspacePodName - oc - get workspace pod name.
          ▼ ShellExecutor.executeCommand - oc get pod -l controller.devfile.io/devworkspace_name=php-hello-world -n admin-devspaces -o name
pod/workspace38c2275186164301-8456f697fc-qgs24
          ▼ KubernetesCommandLineToolsExecutor.getContainerName - oc - get container name.
          ▼ ShellExecutor.executeCommand - oc get pod/workspace38c2275186164301-8456f697fc-qgs24 -o jsonpath='{.spec.containers[*].name}' -n admin-devspaces
tools che-gateway

    ✔ Create  PHP DevSpace
          ▼ ContainerTerminal.execInContainerCommand - oc
          ▼ ShellExecutor.executeCommand - oc exec -i pod/workspace38c2275186164301-8456f697fc-qgs24 -n admin-devspaces -c tools -- sh -c 'cd ${PROJECTS_ROOT}/php-hello-world && php hello-world.php'

Hello, world!

    ✔ Check running application
          ▼ KubernetesCommandLineToolsExecutor.deleteDevWorkspace - oc - delete 'php-hello-world' workspace
          ▼ ShellExecutor.executeCommand - oc patch dw php-hello-world -n admin-devspaces -p '{ "metadata": { "finalizers": null }}' --type merge || true
devworkspace.workspace.devfile.io/php-hello-world patched
          ▼ ShellExecutor.executeCommand - oc delete dw php-hello-world -n admin-devspaces || true
devworkspace.workspace.devfile.io "php-hello-world" deleted
          ▼ ShellExecutor.executeCommand - oc delete dwt che-code-php-hello-world -n admin-devspaces || true
devworkspacetemplate.workspace.devfile.io "che-code-php-hello-world" deleted


  2 passing (31s)


Process finished with exit code 0

What issues does this PR fix or reference?

https://issues.redhat.com/browse/CRW-7539

How to test this PR?

PR Checklist

As the author of this Pull Request I made sure that:

Reviewers

Reviewers, please comment how you tested the PR when approving it.

kubernetesCommandLineToolsExecutor.loginToOcp();
});

test('Create PHP DevSpace', async function (): Promise<void> {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Did you mean PHP workspace?

});

test('Create PHP DevSpace', async function (): Promise<void> {
kubernetesCommandLineToolsExecutor.namespace = 'admin-devspaces';
Copy link
Contributor

@dmytro-ndp dmytro-ndp Oct 22, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The test will be supporting both Eclipse Che and Dev Spaces if use TS_API_TEST_NAMESPACE constant:

kubernetesCommandLineToolsExecutor.namespace: string = API_TEST_CONSTANTS.TS_API_TEST_NAMESPACE || "admin-devspaces"

@dmytro-ndp
Copy link
Contributor

dmytro-ndp commented Oct 22, 2024

@musienko-maxim : the test seems to be the translation of ApiTest_Php.groovy Jenkins script to the typescript, which looks like a step back compare to the another approach which was implemented in the https://github.com/eclipse-che/che/blob/main/tests/e2e/specs/api/DevfileAcceptanceTestAPI.spec.ts, when we are taking commands to execute from devworkspace configuration (see the issue #21514).
It is also adding one more layer - javascript - to the test execution, which makes the test less reliable and more complex when run using Jenkins test pipeline.

It was actually expected to see fixed https://github.com/eclipse-che/che/blob/main/tests/e2e/specs/api/DevfileAcceptanceTestAPI.spec.ts script, to get devworkspace configuration from dashbaord API, not from devfile registry. Sample name to test could be defined by environment variable TS_SELENIUM_DASHBOARD_SAMPLE_NAME.

@dmytro-ndp
Copy link
Contributor

@musienko-maxim : after the call with you I have changed my mind and think that this approach could also be applied, even though it will be a big chunk of work to write test for each devfile sample separately.

Let's try it on Jenkins CI: https://main-jenkins-csb-crwqe.apps.ocp-c1.prod.psi.redhat.com/job/Testing/job/e2e/job/basic/job/typescript-tests/28674/

It would also be great to finish clean up of devfile registry specific code carefully, like DevfilesRegistryHelper to rename to DevfilesHelper

const workdir:string = YAML.parse(devfileContent).commands[0].exec.workingDir;
const commandLine:string = YAML.parse(devfileContent).commands[0].exec.commandLine;
const containerName:string = YAML.parse(devfileContent).commands[0].exec.component;
const runCommandInBash:string = `cd ${workdir} && ${commandLine}`;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It would also be useful to see the actual values of workdir and commandLine: in the logs to recognize original values and the command created from them.

kubernetesCommandLineToolsExecutor.namespace = 'admin-devspaces';
devfileContent = devfilesRegistryHelper.getDevfileContent('php');
const editorDevfileContent: string = devfilesRegistryHelper.obtainCheDevFileEditorFromCheConfigMap('editors-definitions');
kubernetesCommandLineToolsExecutor.workspaceName = YAML.parse(devfileContent).metadata.name;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If we add a random string to the end of workspace name to avoid conflict with existed workspaces having the same name.


test('Create PHP DevSpace', async function (): Promise<void> {
kubernetesCommandLineToolsExecutor.namespace = 'admin-devspaces';
devfileContent = devfilesRegistryHelper.getDevfileContent('php');
Copy link
Contributor

@dmytro-ndp dmytro-ndp Oct 22, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

'php' would better to extract as a DEVFILE_ID constant to make localizing the sample name simpler when investigate the test failure.
You can extract devfile ids of Dev Spaces 3.16 from the next json obtained using request `curl -X GET http://localhost:8081/dashboard/api/airgap-sample -H 'accept: /' -H 'Authorization: Bearer ...:

 [INFO] Devfiles metadata content:
 [
   {
     "id": "php",
     "displayName": "PHP",
     "description": "PHP Stack with PHP",
     "tags": [
       "Tech-Preview",
       "PHP",
       "UBI8"
     ],
     "url": "http://devspaces-dashboard.openshift-devspaces.svc:8080/dashboard/api/airgap-sample/devfile/download?id=php",
     "icon": {
       "mediatype": "image/svg+xml"
     },
     "project": {
       "zip": {
         "filename": "devspaces-samples-php-hello-world-devspaces-3.16-rhel-8.zip"
       }
     },
     "devfile": {
       "filename": "devspaces-samples-php-hello-world-devspaces-3.16-rhel-8-devfile.yaml"
     }
   },
   {
     "id": "dotnet",
     "displayName": ".NET",
     "description": ".NET stack with .NET Core SDK 8, Runtime, C# Language Support and Debugger",
     "tags": [
       "Tech-Preview",
       ".NET",
       "C#",
       ".NET SDK",
       ".NET Runtime",
       "Netcoredbg",
       "Omnisharp",
       "UBI8"
     ],
     "url": "http://devspaces-dashboard.openshift-devspaces.svc:8080/dashboard/api/airgap-sample/devfile/download?id=dotnet",
     "icon": {
       "mediatype": "image/svg+xml"
     },
     "project": {
       "zip": {
         "filename": "devspaces-samples-dotnet-web-simple-devspaces-3.16-rhel-8.zip"
       }
     },
     "devfile": {
       "filename": "devspaces-samples-dotnet-web-simple-devspaces-3.16-rhel-8-devfile.yaml"
     }
   },
   {
     "id": "nodejs-mongodb",
     "displayName": "Node.js MongoDB",
     "description": "Node.js stack with NPM 8, Node.js 16 and MongoDB 3.6",
     "tags": [
       "Node.js",
       "NPM",
       "Express",
       "MongoDB",
       "UBI8"
     ],
     "url": "http://devspaces-dashboard.openshift-devspaces.svc:8080/dashboard/api/airgap-sample/devfile/download?id=nodejs-mongodb",
     "icon": {
       "mediatype": "image/svg+xml"
     },
     "project": {
       "zip": {
         "filename": "devspaces-samples-nodejs-mongodb-sample-devspaces-3.16-rhel-8.zip"
       }
     },
     "devfile": {
       "filename": "devspaces-samples-nodejs-mongodb-sample-devspaces-3.16-rhel-8-devfile.yaml"
     }
   },
   {
     "id": "java-lombok",
     "displayName": "Java Lombok",
     "description": "Java Stack with Project Lombok",
     "tags": [
       "Java",
       "OpenJDK",
       "Maven",
       "Lombok",
       "UBI8"
     ],
     "url": "http://devspaces-dashboard.openshift-devspaces.svc:8080/dashboard/api/airgap-sample/devfile/download?id=java-lombok",
     "icon": {
       "mediatype": "image/svg+xml"
     },
     "project": {
       "zip": {
         "filename": "devspaces-samples-lombok-project-sample-devspaces-3.16-rhel-8.zip"
       }
     },
     "devfile": {
       "filename": "devspaces-samples-lombok-project-sample-devspaces-3.16-rhel-8-devfile.yaml"
     }
   },
   {
     "id": "nodejs-express",
     "displayName": "Node.js Express",
     "description": "Node.js stack with NPM 8, Node.js 16 and Express Web Application",
     "tags": [
       "Node.js",
       "NPM",
       "Express",
       "UBI8"
     ],
     "url": "http://devspaces-dashboard.openshift-devspaces.svc:8080/dashboard/api/airgap-sample/devfile/download?id=nodejs-express",
     "icon": {
       "mediatype": "image/svg+xml"
     },
     "project": {
       "zip": {
         "filename": "devspaces-samples-web-nodejs-sample-devspaces-3.16-rhel-8.zip"
       }
     },
     "devfile": {
       "filename": "devspaces-samples-web-nodejs-sample-devspaces-3.16-rhel-8-devfile.yaml"
     }
   },
   {
     "id": "cpp",
     "displayName": "C/C++",
     "description": "C and C++ Developer Tools stack with GCC, cmake and make",
     "tags": [
       "Tech-Preview",
       "C",
       "C++",
       "Clang",
       "GCC",
       "g++",
       "make",
       "cmake",
       "UBI8"
     ],
     "url": "http://devspaces-dashboard.openshift-devspaces.svc:8080/dashboard/api/airgap-sample/devfile/download?id=cpp",
     "icon": {
       "mediatype": "image/svg+xml"
     },
     "project": {
       "zip": {
         "filename": "devspaces-samples-c-plus-plus-devspaces-3.16-rhel-8.zip"
       }
     },
     "devfile": {
       "filename": "devspaces-samples-c-plus-plus-devspaces-3.16-rhel-8-devfile.yaml"
     }
   },
   {
     "id": "ansible",
     "displayName": "Ansible",
     "description": "Development environment for Ansible playbook creation, testing with Molecule, and ansible-lint checks",
     "tags": [
       "Community",
       "Ansible",
       "Molecule"
     ],
     "url": "http://devspaces-dashboard.openshift-devspaces.svc:8080/dashboard/api/airgap-sample/devfile/download?id=ansible",
     "icon": {
       "mediatype": "image/svg+xml"
     },
     "project": {
       "zip": {
         "filename": "devspaces-samples-ansible-devspaces-demo-devspaces-3.16-rhel-8.zip"
       }
     },
     "devfile": {
       "filename": "devspaces-samples-ansible-devspaces-demo-devspaces-3.16-rhel-8-devfile.yaml"
     }
   },
   {
     "id": "quarkus-rest-api",
     "displayName": "Quarkus REST API",
     "description": "Quarkus stack with a default REST endpoint application sample",
     "tags": [
       "Java",
       "OpenJDK",
       "Maven",
       "Quarkus",
       "UBI8"
     ],
     "url": "http://devspaces-dashboard.openshift-devspaces.svc:8080/dashboard/api/airgap-sample/devfile/download?id=quarkus-rest-api",
     "icon": {
       "mediatype": "image/svg+xml"
     },
     "project": {
       "zip": {
         "filename": "devspaces-samples-quarkus-quickstarts-devspaces-3.16-rhel-8.zip"
       }
     },
     "devfile": {
       "filename": "devspaces-samples-quarkus-quickstarts-devspaces-3.16-rhel-8-devfile.yaml"
     }
   },
   {
     "id": "go",
     "displayName": "Go",
     "description": "Stack with Go",
     "tags": [
       "Tech-Preview",
       "Go",
       "Golang",
       "UBI8"
     ],
     "url": "http://devspaces-dashboard.openshift-devspaces.svc:8080/dashboard/api/airgap-sample/devfile/download?id=go",
     "icon": {
       "mediatype": "image/svg+xml"
     },
     "project": {
       "zip": {
         "filename": "devspaces-samples-golang-health-check-devspaces-3.16-rhel-8.zip"
       }
     },
     "devfile": {
       "filename": "devspaces-samples-golang-health-check-devspaces-3.16-rhel-8-devfile.yaml"
     }
   },
   {
     "id": "python",
     "displayName": "Python",
     "description": "Python Stack with Python 3.9 and pip",
     "tags": [
       "Python",
       "pip",
       "UBI8"
     ],
     "url": "http://devspaces-dashboard.openshift-devspaces.svc:8080/dashboard/api/airgap-sample/devfile/download?id=python",
     "icon": {
       "mediatype": "image/svg+xml"
     },
     "project": {
       "zip": {
         "filename": "devspaces-samples-python-hello-world-devspaces-3.16-rhel-8.zip"
       }
     },
     "devfile": {
       "filename": "devspaces-samples-python-hello-world-devspaces-3.16-rhel-8-devfile.yaml"
     }
   }
 ]

tests/e2e/utils/DevfilesHelper.ts Dismissed Show dismissed Hide dismissed
tests/e2e/utils/DevfilesHelper.ts Dismissed Show dismissed Hide dismissed
tests/e2e/utils/DevfilesHelper.ts Dismissed Show dismissed Hide dismissed
tests/e2e/utils/DevfilesHelper.ts Dismissed Show dismissed Hide dismissed
Copy link
Contributor

@dmytro-ndp dmytro-ndp left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@musienko-maxim musienko-maxim merged commit 8cb40db into main Oct 29, 2024
5 checks passed
@musienko-maxim musienko-maxim deleted the fix-dev-spaces-devfile-api-tests-to-avoid-using-an-absolute-devfile-registry branch October 29, 2024 13:45
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants