Project

General

Profile

Actions

action #87695

closed

coordination #58184: [saga][epic][use case] full version control awareness within openQA

coordination #48641: [epic] Trigger openQA tests in pull requests of any product github pull request

Full openQA test development, maintenance and administration from browser without the need of a local terminal size:M

Added by okurz over 3 years ago. Updated 3 months ago.

Status:
Resolved
Priority:
Low
Assignee:
Category:
Feature requests
Target version:
Start date:
Due date:
% Done:

0%

Estimated time:

Description

Motivation

To allow easier workflows for web centric users, e.g. using https://github.com/features/codespaces , we should offer possibilities to interact with openQA without needing a local terminal with openqa cli tools, maybe using curl only.

Acceptance criteria

  • AC1: openQA jobs can be triggered from remote web-based IDEs (or just terminals)

Suggestions

Further details

Related to #86063


Files


Related issues 4 (3 open1 closed)

Related to openQA Project - coordination #154768: [saga][epic][ux] State-of-art user experience for openQANew2017-01-232024-09-20

Actions
Copied from openQA Project - action #86063: [epic] Add possibility to trigger openQA API calls, e.g. single "jobs", without the need of the client / over the webUI / with curlBlockedokurz2021-01-13

Actions
Copied to openQA Project - action #161399: Use Tumbleweed again for openqa-single-instance container size:SResolvedjbaier_cz

Actions
Copied to openQA Project - action #162248: Codespaces: Improve openqa-bootstrapNew

Actions
Actions #1

Updated by okurz over 3 years ago

  • Copied from action #86063: [epic] Add possibility to trigger openQA API calls, e.g. single "jobs", without the need of the client / over the webUI / with curl added
Actions #2

Updated by okurz over 1 year ago

  • Target version changed from future to Ready
Actions #3

Updated by okurz over 1 year ago

  • Subject changed from [epic] full openQA test development, maintenance and administration from browser without the need of a local terminal to Full openQA test development, maintenance and administration from browser without the need of a local terminal
  • Description updated (diff)
Actions #4

Updated by okurz over 1 year ago

  • Description updated (diff)
Actions #5

Updated by okurz over 1 year ago

  • Subject changed from Full openQA test development, maintenance and administration from browser without the need of a local terminal to Full openQA test development, maintenance and administration from browser without the need of a local terminal size:M
  • Description updated (diff)
  • Status changed from New to Workable
Actions #7

Updated by okurz about 1 year ago

  • Target version changed from Ready to future
Actions #8

Updated by szarate 7 months ago

Actions #9

Updated by okurz 5 months ago

  • Description updated (diff)
  • Target version changed from future to Ready
Actions #10

Updated by tinita 4 months ago

  • Status changed from Workable to In Progress
  • Assignee set to tinita
Actions #11

Updated by okurz 4 months ago

  • Description updated (diff)
Actions #12

Updated by tinita 4 months ago

I was able to build from this Dockerfile and run it in codespace:

FROM docker.io/opensuse/leap:15.6

RUN zypper in -y git bash

RUN zypper in -y openQA-single-instance openQA-bootstrap \
    qemu-arm qemu-ppc qemu-x86 qemu-tools sudo iputils os-autoinst-distri-opensuse-deps && \
    zypper clean -a

Branch: https://github.com/perlpunk/openQA/tree/codespace

I started openqa-bootstrap and had a working webui on https://some-name-80.app.github.dev.

I cloned this test: https://openqa.opensuse.org/tests/4191283
However the test died:

[2024-05-15T21:55:44.230858Z] [info] [pid:6527] ::: backend::baseclass::die_handler: Backend process died, backend errors are reported below in the following lines:
  QEMU terminated before QMP connection could be established. Check for errors below
[2024-05-15T21:55:44.231141Z] [info] [pid:6527] ::: OpenQA::Qemu::Proc::save_state: Saving QEMU state to qemu_state.json
[2024-05-15T21:55:44.234059Z] [debug] [pid:6527] Passing remaining frames to the video encoder
[2024-05-15T21:55:44.334945Z] [debug] [pid:6527] Waiting for video encoder to finalize the video
[2024-05-15T21:55:44.335038Z] [debug] [pid:6527] The built-in video encoder (pid 6530) terminated
[2024-05-15T21:55:44.335922Z] [debug] [pid:6527] QEMU: QEMU emulator version 8.2.2 (SUSE Linux Enterprise 15)
[2024-05-15T21:55:44.335985Z] [debug] [pid:6527] QEMU: Copyright (c) 2003-2023 Fabrice Bellard and the QEMU Project developers
[2024-05-15T21:55:44.336058Z] [warn] [pid:6527] !!! : qemu-system-x86_64: CPU model 'host' requires KVM or HVF
[2024-05-15T21:55:44.336762Z] [debug] [pid:6527] sending magic and exit
[2024-05-15T21:55:44.337059Z] [debug] [pid:6294] received magic close
[2024-05-15T21:55:44.441401Z] [warn] [pid:6294] !!! main: failed to start VM at /usr/lib/os-autoinst/backend/driver.pm line 104.

[2024-05-15T21:55:44.441738Z] [debug] [pid:6294] stopping command server 6516 because test execution ended through exception

I also cloned a different test using a Python test module and it complained that Inline::Python is not installed.

Actions #13

Updated by tinita 4 months ago

Adding "runArgs": [ "--privileged", "--device", "/dev/kvm" ] in devcontainer.json did not help

Actions #14

Updated by tinita 4 months ago

I added QEMU_APPEND="-enable-kvm" to openqa-clone-job. Now I get:

[2024-05-16T08:45:29.471397Z] [debug] [pid:6331] QEMU: Copyright (c) 2003-2023 Fabrice Bellard and the QEMU Project developers
[2024-05-16T08:45:29.471444Z] [debug] [pid:6331] QEMU: Could not access KVM kernel module: Permission denied
[2024-05-16T08:45:29.471548Z] [warn] [pid:6331] !!! : qemu-system-x86_64: failed to initialize kvm: Permission denied
[2024-05-16T08:45:29.472298Z] [debug] [pid:6331] sending magic and exit
[2024-05-16T08:45:29.472581Z] [debug] [pid:6098] received magic close
[2024-05-16T08:45:29.577241Z] [warn] [pid:6098] !!! main: failed to start VM at /usr/lib/os-autoinst/backend/driver.pm line 104.
Actions #15

Updated by tinita 4 months ago

I did:

chown root:kvm /dev/kvm

Now I get:

[2024-05-16T08:49:46.622010Z] [warn] [pid:8060] !!! : qemu-system-x86_64: -vnc :91,share=force-shared: Failed to find an available port: Address already in use
Actions #16

Updated by tinita 4 months ago

In our collab session we tried several things to change the vnc port.
In the end it helped to restart the worker instance with an instance number of 10 instead of 1. (we needed to create the pool directory first)
With that qemu started and the test passed.

We didn't find out why the default 5091 port did not work, as there was nothing else listening on that port.

But it would be good if the bootstrap script and our code was a bit more flexible to configure certain ports.
Also it would be nice if one could just stop everything and restart the bootstrap script after making changes. Running the bootstrap script twice currently fails early when adding the zypper repository (complaining that it already exists).

Actions #17

Updated by tinita 4 months ago

https://github.com/os-autoinst/openQA/pull/5644 Make VNC port offset configurable

Actions #18

Updated by tinita 4 months ago · Edited

https://github.com/os-autoinst/openQA/pull/5654 Restructure openqa-bootstrap
Draft: https://github.com/os-autoinst/openQA/pull/5648 Add devcontainer for Codespaces

I am using a Dockerfile for building a container.

I cannot use the existing single instance container. It's (of course) one of the first things I tried but it failed with a generic error message.
You can try it out yourself in the following branches. Just go to "Code", select "Codespaces" and click on the plus sign.
For me it only worked for Leap. The single instance container is Tumbleweed, so I assume that's the reason it also doesn't work.

https://github.com/perlpunk/openQA/tree/codespace-single-instance-container (error)

    "name": "openQA Single Instance",
    "image": "registry.opensuse.org/devel/openqa/containers/openqa-single-instance",

https://github.com/perlpunk/openQA/tree/codespace-tumbleweed (error)

    "name": "openQA Single Instance",
    "image": "registry.opensuse.org/opensuse/tumbleweed:latest",

https://github.com/perlpunk/openQA/tree/codespace-leap (works)

    "name": "openQA Single Instance",
    "image": "registry.opensuse.org/opensuse/leap:15.6",

I attached the error I get for the first two containers.

I don't know a way to find out what the actual problem is, and yes, of course that is probably something we have to figure out at some point.

Some more information I got by searching for "log" in the command palette:

2024-05-21 22:35:28.745 [error] exception was thrown by handler. exception: failed to start vs code remote server.: Error: exception was thrown by handler. exception: failed to start vs code remote server.
    at Object.onEnd (https://assets.github.dev/static/66.bbfdbcf5888791c58e37.js:1:283263)
    at https://assets.github.dev/static/66.bbfdbcf5888791c58e37.js:1:24222
    at https://assets.github.dev/static/66.bbfdbcf5888791c58e37.js:1:11479
    at Array.forEach (<anonymous>)
    at e.rawOnError (https://assets.github.dev/static/66.bbfdbcf5888791c58e37.js:1:11441)
    at e.onTransportHeaders (https://assets.github.dev/static/66.bbfdbcf5888791c58e37.js:1:9014)
    at y.<anonymous> (https://assets.github.dev/static/app.3abbf6cfce04d31517f6.js:1:156890)
    at Generator.next (<anonymous>)
    at https://assets.github.dev/static/app.3abbf6cfce04d31517f6.js:1:154060
    at new Promise (<anonymous>)

Maybe it only happens for me, that's also possible.

(edit: I get the same error in chromium, chrome and firefox)

Actions #19

Updated by tinita 4 months ago

Developer Tools reveals some more errors:

commons-app-axios.cj…f64113844588ba.js:1 Refused to set unsafe header "User-Agent"
371.a061e5c….js:1 vscs:web-client:ae39:codespaces-component:workbench-page Tunnel client is unconnected, fetching tunnel and connecting 
Object
commons-app-axios.cj…f64113844588ba.js:1 Refused to set unsafe header "User-Agent"
371.a061e5c….js:1 vscs:web-client:ae39:codespaces-component:workbench-page Created port https/16635 with privacy 'private'
371.a061e5c….js:1 vscs:web-client:ae39:codespaces-component:workbench-page:workbench:vscs:web-client:ae39:codespaces-component:workbench-page:workbench:vscode-workbench Failed to complete start-remote-server with gRPC exception was thrown by handler. exception: failed to start vs code remote server.
Error: exception was thrown by handler. exception: failed to start vs code remote server.
    at Object.onEnd (https://assets.github.dev/static/66.bbfdbcf….js:1:283263)
    at https://assets.github.dev/static/66.bbfdbcf….js:1:24222
    at https://assets.github.dev/static/66.bbfdbcf….js:1:11479
    at Array.forEach (<anonymous>)
    at e.rawOnError (https://assets.github.dev/static/66.bbfdbcf….js:1:11441)
    at e.onTransportHeaders (https://assets.github.dev/static/66.bbfdbcf….js:1:9014)
    at y.<anonymous> (https://assets.github.dev/static/app.3abbf6c….js:1:156890)
    at Generator.next (<anonymous>)
    at https://assets.github.dev/static/app.3abbf6c….js:1:154060
    at new Promise (<anonymous>)
371.a061e5c….js:1 vscs:web-client:ae39:codespaces-component:workbench-page:workbench:vscs:web-client:ae39:codespaces-component:workbench-page:workbench:vscode-workbench Failed to execute start-remote-server: undefined
371.a061e5c….js:1 vscs:web-client:ae39:codespace-state-watcher codespace state -> Available
371.a061e5c….js:1 vscs:web-client:ae39:workbench-telemetry:telemetry-service ["codespaces/web/get-connection-token-error",{"errorCode":-1,"errorType":"GenericError","errorMessage":"exception was thrown by handler. exception: failed to start vs code remote server.","originalErrorType":"[no original type]","errorDidCatch":false,"stack":"Error: exception was thrown by handler. exception: failed to start vs code remote server.\n    at Object.onEnd [PATH]/66.bbfdbcf….js:1:283263)\n    at [PATH]/66.bbfdbcf….js:1:24222\n    at [PATH]/66.bbfdbcf….js:1:11479\n    at Array.forEach (<anonymous>)\n    at e.rawOnError [PATH]/66.bbfdbcf….js:1:11441)\n    at e.onTransportHeaders [PATH]/66.bbfdbcf….js:1:9014)\n    at y.<anonymous> [PATH]/app.3abbf6c….js:1:156890)\n    at Generator.next (<anonymous>)\n    at [PATH]/app.3abbf6c….js:1:154060\n    at new Promise (<anonymous>)"}]
log.ts:439   ERR Error received from starting extension host (kind: Remote)
log.ts:439   ERR Error: exception was thrown by handler. exception: failed to start vs code remote server.
    at Object.onEnd (66.bbfdbcf….js:1:283263)
    at 66.bbfdbcf….js:1:24222
    at 66.bbfdbcf….js:1:11479
    at Array.forEach (<anonymous>)
    at e.rawOnError (66.bbfdbcf….js:1:11441)
    at e.onTransportHeaders (66.bbfdbcf….js:1:9014)
    at y.<anonymous> (app.3abbf6c….js:1:156890)
    at Generator.next (<anonymous>)
    at app.3abbf6c….js:1:154060
    at new Promise (<anonymous>)
...
But some of them I also see when it's working.
Actions #20

Updated by livdywan 4 months ago

Just to recap the points from the unblock:

  • Switching to Leap for now would make things work
  • Issues with Tumbleweed are not currently reproducible outside of Codespaces
  • Moving the existing container to leap, or making a new one (whichever is easier) so an image can be specified to avoid the slow re-builds for every person using it
  • Codespaces as root works fine, would be nice if that can be a user, but could probably be left as-is as well
Actions #21

Updated by tinita 4 months ago

I'm trying out the single-instance-container with Leap 15.6. Codespace runs into the same error message using registry.opensuse.org/home/tinita/single-instance-openqa/containers/opensuse/openqa-single-instance:latest , so I'm commenting out everything and start commenting in step by step to see what's the problem.
It's a bit annoying, as a repeated click on "Trigger services" doesn't fetch new sources. It only works once.
So I have to create a new branch in git everytime and change the url in the _service file.
Maybe time for a bug report for OBS.

Actions #22

Updated by tinita 3 months ago

I'm making very slow progress.

I'm now trying out Leap 1.5, because 15.6 did not work:
During building in OBS, it has a newer version of qemu available than later when the container is running. This seems to be special to Leap 15.6.

Now whenever I want to try out the container in codespaces and call the bootstrap script I get problems with download.pensuse.org:

Signature verification failed for file 'repomd.xml' from repository 'Update repository of openSUSE Backports'. Continue? [yes/no] (no): no
Retrieving repository 'Update repository of openSUSE Backports' metadata ................[error]
Repository 'Update repository of openSUSE Backports' is invalid.
[repo-backports-update|http://download.opensuse.org/update/leap/15.5/backports/] Valid metadata not found at specified URL
History:
 - Signature verification failed for repomd.xml

This is getting annoying and I don't know how to proceed currently.
I can try and to something else and regularly check again if it is working, but I would finally like to concentrate on doing something for a longer time.

Now after writing this I tried again and download.o.o was fine again.

What's also annoying is that this costs time and storage on Github. There is a certain amount of CPU time and storage included, but if I keep a container running in the background only because download.o.o is unstable and I need to retry regularly my included time and storage will be exceeding its limit at some point.
I have ~13 hours left now for the next 11 days.

Actions #23

Updated by tinita 3 months ago

https://github.com/os-autoinst/openQA/pull/5664 Downgrade single-instance-container to Leap
I had to trigger services manually here:
https://build.opensuse.org/package/show/devel:openQA/openQA-single-instance-container
Now the source has been updated and it shows as unresolvable.
Need to figure out what to do.

x86_64
 unresolvable
The build can not begin, because required packages are either missing or not explicitly defined.

 Repository has been published
unresolvable: nothing provides container:opensuse/leap:15.5
Actions #24

Updated by tinita 3 months ago

I changed the Meta for the package and added <enable repository="containers15.5"/>. Now it built.
registry.opensuse.org/devel/openqa/containers15.5/openqa-single-instance:latest should be the new container url.

Actions #26

Updated by okurz 3 months ago

Please also see https://github.com/os-autoinst/openQA/pull/5664/files#r1623190048 about the container versions. If we have problems with specific container versions but depending on the environment then we can also try to build different versions in parallel but keep Tumbleweed the default.

Actions #27

Updated by livdywan 3 months ago

okurz wrote in #note-26:

Please also see https://github.com/os-autoinst/openQA/pull/5664/files#r1623190048 about the container versions. If we have problems with specific container versions but depending on the environment then we can also try to build different versions in parallel but keep Tumbleweed the default.

This was already discussed at length with multiple team members. I think Tina did or wanted to file a follow-up ticket on the container issues. Let's not go in circles here.

Actions #28

Updated by tinita 3 months ago

  • Copied to action #161399: Use Tumbleweed again for openqa-single-instance container size:S added
Actions #29

Updated by tinita 3 months ago

I created #161399 and https://github.com/orgs/community/discussions/127083 to track the Codespaces + Tumbleweed bug.

Actions #30

Updated by tinita 3 months ago

https://github.com/os-autoinst/openQA/pull/5671 Add documentation for codespaces

Actions #32

Updated by tinita 3 months ago

  • Status changed from In Progress to Feedback
Actions #33

Updated by mpagot 3 months ago · Edited

Personal idea is that Codespace is about having a preconfigured IDE to contribute to the repo directly from within the browser. With this personal point of view I've given a try to Codespace in https://github.com/os-autoinst/openQA

I create one, wait for the creation, then opened a second terminal to run tail -f /var/log/openqa-bootstrap.log and wait.

Then I opened in the editor the file https://github.com/os-autoinst/openQA/blob/master/docs/Contributing.asciidoc and read through it. One of the first indication there is about how to tidy the code. So I opened a terminal in the codespace and typed make tidy.

What I get is

codespaces-3ad963:/workspaces/openQA # make  tidy
bash: make: command not found

What I's suggesting is to have more tools installed in the image, not only to be able to trigger test in openQA but also to navigate and write code following the suggestions from the contribute document.

P.S. Some more experiments

codespaces-3ad963:/workspaces/openQA #  zypper in make nodejs npm

...


codespaces-3ad963:/workspaces/openQA #  make tidy

...
tools/tidy
Wrong version of perltidy. Found '20230309', expected '20240511'. Consider '--force' but results might not be consistent.
make: *** [Makefile:325: tidy-perl] Error 1

Using zypper in openQA-devel, as suggested in the contribute doc, does not solve this particular perltidy issue

Actions #34

Updated by tinita 3 months ago

  • Status changed from Feedback to Resolved
Actions #35

Updated by tinita 3 months ago

  • Status changed from Resolved to Workable

I noticed two problems:

  1. Now that openqa-bootstrap is run as postAttachCommand, it is also run when you restart the codespace. This will do some things twice, for example the client.conf now has two entries for localhost:

    cat /etc/openqa/client.conf
    ## you can generate key and secret via the web ui
    ##
    #[openqa.example.com]
    #key = foo
    #secret = bar
    [localhost]
    key = 802F8BC8F28E4883
    secret = 160ECB7217B3280D
    [localhost]
    key = B698A7F06975535A
    secret = 0FECC0E3EC7FB337
    
  2. When restarting the codespace, it seems to lose the chown root:kvm /dev/kvm although to me it looks like it should be run once:

    "postCreateCommand": "chown root:kvm /dev/kvm"
    

    and I don't know what is resetting the permissions after restarting.

Actions #36

Updated by tinita 3 months ago · Edited

  • Status changed from Workable to In Progress

I think I fixed the second problem: https://github.com/os-autoinst/os-autoinst-distri-openQA/pull/178 codespace: Run chown as postStartCommand

Actions #37

Updated by tinita 3 months ago

  • Copied to action #162248: Codespaces: Improve openqa-bootstrap added
Actions #38

Updated by tinita 3 months ago

  • Status changed from In Progress to Feedback

Created #162248 for the first problem.

Actions #39

Updated by tinita 3 months ago

Actions #40

Updated by tinita 3 months ago

  • Status changed from Feedback to Resolved

Followup tickets exist

Actions

Also available in: Atom PDF