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

ODO doesn't support Devfile schema v.2.2.2 #7244

Closed
vrubezhny opened this issue Jun 6, 2024 · 9 comments
Closed

ODO doesn't support Devfile schema v.2.2.2 #7244

vrubezhny opened this issue Jun 6, 2024 · 9 comments
Labels
area/devfile-spec Issues or PRs related to the Devfile specification and how odo handles and interprets it. kind/bug Categorizes issue or PR as related to a bug.

Comments

@vrubezhny
Copy link

/kind bug

ODO fails to initialize a component when Devfile schema v.2.2.2 is used.

What versions of software are you using?

Operating System:

Fedora Linux 6.8.7-100.fc38.x86_64

... but the issue is not OS/Arch dependent

Output of odo version:

$ odo version
odo v3.15.0 (10b5e8a)

Server: https://127.0.0.1:42801
Kubernetes: v1.27.3
Podman Client: 4.9.4

How did you run odo exactly?

$ odo init --name=component1 --devfile=nodejs --starter=nodejs-starter

Actual behavior

ODO reports error: ✗ unable to parse devfile: failed to populateAndParseDevfile: unable to find schema for version "2.2.2". The parser supports devfile schema for version 2.0.0, 2.1.0, 2.2.0, v1alpha2

Expected behavior

The ODO init command should be executed successfully

Any logs, error output, etc?

$ mkdir starter
$ cd starter/
$ odo init --name=component1 --devfile=nodejs --starter=nodejs-starter
  __
 /  \__     Initializing a new component
 \__/  \    
 /  \__/    odo version: v3.15.0 (10b5e8a8f)
 \__/

 ✓  Downloading devfile "nodejs" [1s]
 ✗  unable to parse devfile: failed to populateAndParseDevfile: unable to find schema for version "2.2.2". The parser supports devfile schema for version 2.0.0, 2.1.0, 2.2.0, v1alpha2
the command failed, the devfile has been removed from current directory
@openshift-ci openshift-ci bot added the kind/bug Categorizes issue or PR as related to a bug. label Jun 6, 2024
@github-actions github-actions bot added the needs-triage Indicates an issue or PR lacks a `triage/*` and requires one. label Jun 6, 2024
@rm3l
Copy link
Member

rm3l commented Jun 6, 2024

Hi @vrubezhny ,

I can see that this issue is fixed in the main branch (6d83e40) of odo, certainly because the Devfile library was updated in #7240.

$ odo init --name=component1 --devfile=nodejs --starter=nodejs-starter         
  __
 /  \__     Initializing a new component
 \__/  \    
 /  \__/    odo version: v3.15.0 (6d83e4043)
 \__/

 ✓  Downloading devfile "nodejs" [986ms]
 ✓  Downloading starter project "nodejs-starter" [417ms]

Your new component 'component1' is ready in the current directory.
To start editing your component, use 'odo dev' and open this folder in your favorite IDE.
Changes will be directly reflected on the cluster.

The latest release of odo is a bit "old", and there is currently no plan to release a newer version (unless there are critical or security issues to fix of course).

Would it make sense for you to use nightly builds of odo instead? See https://odo.dev/docs/overview/installation#nightly-builds
They are quite stable and AFAICT, the diff between 3.15 and the main branch is mostly around dependency updates and fixing tests: v3.15.0...main

@vrubezhny
Copy link
Author

@rm3l Thanks! We'll consider using the nightly builds for 'odo'. This definitely could be a solution at the moment.

@rm3l rm3l added area/devfile-spec Issues or PRs related to the Devfile specification and how odo handles and interprets it. and removed needs-triage Indicates an issue or PR lacks a `triage/*` and requires one. labels Jun 10, 2024
@vrubezhny
Copy link
Author

The problem with using the nightly builds is that the download links are "static" - so we're not able to save sha256 for a binary archive and then verify the archive downloaded much later by such a "static" link against the saved sha256 value...

For the releases we're downloading "an approved" binary version and usually an archive for each version has its unique sha256 which never changes, so for a released version we can download the same archive later and verify it against the sha256 saved to that version. With "static" download links it's not possible (also, I believe, the track of nightly builds isn't kept, so with a time passed we'll be downloading some other archive using the same URL).

@vrubezhny
Copy link
Author

@rm3l Thanks a lot for 3d77fe9! 👍

@rm3l
Copy link
Member

rm3l commented Jun 17, 2024

Hey @vrubezhny !
You noticed before I pinged you :-) Yes, this is a quick experiment to see if it would help in the future for similar situations. I plan anyway to create a 3.16.0 release today.

@vrubezhny
Copy link
Author

Hey @vrubezhny ! You noticed before I pinged you :-) Yes, this is a quick experiment to see if it would help in the future for similar situations. I plan anyway to create a 3.16.0 release today.

This should help us a lot in case the nightly build archives and according *.sha256 files that has commit ID in their names history is kept in time as we need to have a possibility to save the archives URLs and their sha checksums for the archives, and then later, when we need to download the binary we were able to verify it against the saved sha checksum. If this workflow works - it'll be great help for us as we won't need to ask ODO team to perform a new release every time the Devfile schema version is updated or anything similar happens in the future.

Thanks!

@rm3l
Copy link
Member

rm3l commented Jun 18, 2024

@vrubezhny So I tried to create a 3.16.0 release yesterday but hit a roadblock with the RH internal build systems, which, I think, would require a few additional changes..
As I didn't plan to spend too much time on those build issues, I would suggest that you move forward with the nightly binaries (pinned to a commit ID).
Let me know if you run into any issues with the nightly binaries.
Thanks.

@rm3l
Copy link
Member

rm3l commented Jun 25, 2024

@vrubezhny FYI, I was keeping an eye on the internal issues that were blocking a new release, and they have all been fixed recently.
A new release of odo v3.16.1 is now available: https://developers.redhat.com/content-gateway/rest/mirror/pub/openshift-v4/clients/odo/v3.16.1 🎉

Closing this issue now, but feel free to reopen if the issue still persists.

/close

@openshift-ci openshift-ci bot closed this as completed Jun 25, 2024
Copy link

openshift-ci bot commented Jun 25, 2024

@rm3l: Closing this issue.

In response to this:

@vrubezhny FYI, I was keeping an eye on the internal issues that were blocking a new release, and they have all been fixed recently.
A new release of odo v3.16.1 is now available: https://developers.redhat.com/content-gateway/rest/mirror/pub/openshift-v4/clients/odo/v3.16.1 🎉

Closing this issue now, but feel free to reopen if the issue still persists.

/close

Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes-sigs/prow repository.

@github-project-automation github-project-automation bot moved this to Done ✅ in odo Project Jun 25, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
area/devfile-spec Issues or PRs related to the Devfile specification and how odo handles and interprets it. kind/bug Categorizes issue or PR as related to a bug.
Projects
Archived in project
Development

No branches or pull requests

2 participants