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

Proposal for odo deploy #3368

Merged

Conversation

neeraj-laad
Copy link
Contributor

What type of PR is this?
/kind design
[skip ci]

What does does this PR do / why we need it:
This is a design proposal for adding limited outer-loop capabilities to odo. Additional information non this is captured here: #3300

Which issue(s) this PR fixes:
Relates to: #3300

How to test changes / Special notes to the reviewer:
This is a design proposal, once the design is agreed upon we can submit a PR for the implementation. We might start making some progress on a prototype based on this proposal and then adjust as the design evolves.

Initial design proposal for adding a odo deply command.

This is related to redhat-developer#3300

Signed-off by: Neeraj Laad <neeraj.laad@gmail.com>
Updated future evolution

Signed-off-by: Neeraj Laad <neeraj.laad@gmail.com>
Signed-off-by: Neeraj Laad <neeraj.laad@gmail.com>
@openshift-ci-robot
Copy link
Collaborator

Hi @neeraj-laad. Thanks for your PR.

I'm waiting for a openshift member to verify that this patch is reasonable to test. If it is, they should reply with /ok-to-test on its own line. Until that is done, I will not automatically test new commits in this PR, but the usual testing commands by org members will still work. Regular contributors should join the org to skip this step.

Once the patch is verified, the new status will be reflected by the ok-to-test label.

I understand the commands that are listed here.

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/test-infra repository.

@openshift-ci-robot openshift-ci-robot added the needs-ok-to-test Indicates a PR that requires an org member to verify it is safe to test. Required by Prow. label Jun 17, 2020
@codecov
Copy link

codecov bot commented Jun 17, 2020

Codecov Report

Merging #3368 into master will increase coverage by 0.11%.
The diff coverage is n/a.

Impacted file tree graph

@@            Coverage Diff             @@
##           master    #3368      +/-   ##
==========================================
+ Coverage   45.95%   46.07%   +0.11%     
==========================================
  Files         111      111              
  Lines       11034    11072      +38     
==========================================
+ Hits         5071     5101      +30     
- Misses       5473     5479       +6     
- Partials      490      492       +2     
Impacted Files Coverage Δ
pkg/util/util.go 55.26% <0.00%> (ø)
pkg/url/url.go 64.14% <0.00%> (+0.83%) ⬆️
pkg/sync/sync.go 47.52% <0.00%> (+0.99%) ⬆️

Continue to review full report at Codecov.

Legend - Click here to learn more
Δ = absolute <relative> (impact), ø = not affected, ? = missing data
Powered by Codecov. Last update c7dbe2c...07adf2d. Read the comment docs.

Updated metadata to attributes
Fixed formatting for yaml
@girishramnani
Copy link
Contributor

Some questions -

  • Would the odo log work with the deployed slim container?
  • Would the odo exec command be allowed to run commands on the deployed prod container?
  • What kind of kubernetes resource would the Image be deployed as? Like a low level Pod resource or a replicated Deployment or something else?
  • Would we allow configure health checks (liveness probes)?

@adisky
Copy link
Contributor

adisky commented Jun 18, 2020

/ok-to-test

@openshift-ci-robot openshift-ci-robot added ok-to-test Indicates a non-member PR verified by an org member that is safe to test. and removed needs-ok-to-test Indicates a PR that requires an org member to verify it is safe to test. Required by Prow. labels Jun 18, 2020
docs/proposals/odo-deploy.md Outdated Show resolved Hide resolved
docs/proposals/odo-deploy.md Outdated Show resolved Hide resolved
docs/proposals/odo-deploy.md Outdated Show resolved Hide resolved
@kadel
Copy link
Member

kadel commented Jun 18, 2020

  • Would the odo log work with the deployed slim container?

yes, but we can address this later.

  • Would the odo exec command be allowed to run commands on the deployed prod container?

yes, but we can address this later.

  • What kind of kubernetes resource would the Image be deployed as? Like a low level Pod resource or a replicated Deployment or something else?

That will be complete under the devfile creator control. deployment-manifest: could point to anything. It can be Pod, Deployment, Knative Service, or CR, or even multiple resources-

  • Would we allow configure health checks (liveness probes)?

Same as above, it will depend on what will be defined in deployment-manifest should be able to add there almost anything they want.

Copy link
Member

@dharmit dharmit left a comment

Choose a reason for hiding this comment

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

Mostly questions based solely on what I read on this PR. Please feel free to point me to docs that you feel one must read to understand this better. I'm trying to grok the google doc I found for "Devfile 2.1.0 proposal".

docs/proposals/odo-deploy.md Show resolved Hide resolved
docs/proposals/odo-deploy.md Show resolved Hide resolved
docs/proposals/odo-deploy.md Outdated Show resolved Hide resolved
docs/proposals/odo-deploy.md Show resolved Hide resolved
docs/proposals/odo-deploy.md Outdated Show resolved Hide resolved
docs/proposals/odo-deploy.md Outdated Show resolved Hide resolved
docs/proposals/odo-deploy.md Outdated Show resolved Hide resolved
docs/proposals/odo-deploy.md Outdated Show resolved Hide resolved
docs/proposals/odo-deploy.md Outdated Show resolved Hide resolved
@neeraj-laad
Copy link
Contributor Author

neeraj-laad commented Jun 18, 2020

@girishramnani

  • Would the odo log work with the deployed slim container?

Based on current thinking No. It would be good to not intermingle the commands for inner-loop/outer-loop to start with. But we can put this as a future piece if we think it might be useful.

  • Would the odo exec command be allowed to run commands on the deployed prod container?

I would think No - purely because I do not understand what use case will need this. Can you think of a reason why this would be useful?

  • What kind of kubernetes resource would the Image be deployed as? Like a low level Pod resource or a replicated Deployment or something else?

We would like to support any Kubernetes resource. So devfile creator can decide what makes most sense. standard k8s deployment, knative service, operator custom resource etc.

  • Would we allow configure health checks (liveness probes)?

My current thought is that we will not do anything over and above what the devfile creator specifies. If they want specific health/liveness probes they need to provide those in the deployment manifest. or maybe consider this as a future piece.

@sbose78
Copy link
Member

sbose78 commented Jun 18, 2020

@neeraj-laad Could you please address in your proposal why we aren't going to use the BuildConfig Dockerfile strategy in OpenShift ?

@girishramnani @kadel @dharmit

Would it be messy if we had a couple of if-else blocks where

  • if openshift, use buildconfig and push to imagestream
  • if non-openshift, use plain pods, and push to quay.io-ish registry with credentials.

@kadel
Copy link
Member

kadel commented Jun 18, 2020

Would it be messy if we had a couple of if-else blocks where

  • if openshift, use buildconfig and push to imagestream
  • if non-openshift, use plain pods, and push to quay.io-ish registry with credentials.

This would be ok. We already doing something similar for URLs where odo creates Routes when working with OpenShift and Ingress when working with Kubernetes

@neeraj-laad
Copy link
Contributor Author

@sbose78 @kadel I have updated to proposal to use BuildConfig if present on cluster or use kaniko if not.

This will mean the first PR could provide OpenShift support using BuildConfig. and a follow on PR could add support for generic Kubernetes with Kaniko.

Copy link
Member

@kadel kadel left a comment

Choose a reason for hiding this comment

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

Just one small comment.
Overall this looks good
/approve

docs/proposals/odo-deploy.md Outdated Show resolved Hide resolved
@openshift-ci-robot
Copy link
Collaborator

[APPROVALNOTIFIER] This PR is APPROVED

This pull-request has been approved by: kadel

The full list of commands accepted by this bot can be found here.

The pull request process is described here

Needs approval from an approver in each of these files:

Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment

@openshift-ci-robot openshift-ci-robot added the approved Indicates a PR has been approved by an approver from all required OWNERS files. Required by Prow. label Jun 23, 2020
@kadel
Copy link
Member

kadel commented Jun 24, 2020

/lgtm

overriding CI, we don't need tests for this PR
/override ci/prow/v4.5-integration-e2e
/override ci/prow/v4.4-integration-e2e
/override ci/prow/v4.3-integration-e2e
/override ci/prow/v4.2-integration-e2e

@openshift-ci-robot
Copy link
Collaborator

@kadel: Overrode contexts on behalf of kadel: ci/prow/v4.2-integration-e2e, ci/prow/v4.3-integration-e2e, ci/prow/v4.4-integration-e2e, ci/prow/v4.5-integration-e2e

In response to this:

/lgtm

overriding CI, we don't need tests for this PR
/override ci/prow/v4.5-integration-e2e
/override ci/prow/v4.4-integration-e2e
/override ci/prow/v4.3-integration-e2e
/override ci/prow/v4.2-integration-e2e

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/test-infra repository.

@openshift-ci-robot openshift-ci-robot added the lgtm Indicates that a PR is ready to be merged. Required by Prow. label Jun 24, 2020
@openshift-merge-robot openshift-merge-robot merged commit aa894f5 into redhat-developer:master Jun 24, 2020
@jaideepr97
Copy link

jaideepr97 commented Jun 25, 2020

Hi folks, based on my understanding of this proposal, I had a few questions (apologies for any trivial/previously answered questions) :-

  1. odo deploy flags mentions multiple ways to handle flag inputs (registry credentials etc) depending on the type of target ( k8s/OS) - is the target specified in the devfile or supplied in some other way?

  2. I understand that as of now odo deploy is intended to only be used for deployments in the dev environment. However, I was wondering, given enough time to mature through successive improvements, if there was any likelihood of configuring existing pipelines to leverage odo deploy internally to deploy applications to prod and other environments at some point down the line

A couple peripheral questions that also seemed relevant to me :

  1. Is the intention of having a devfile that the user would not have to worry about any of the deployment details at all? Because as per my understanding the devfile points to variable resources like the deployment manifest and source URL which would probably be specific to an application and can't just be picked up by odo deploy from a stock devfile for a particular language/framework

  2. Has the structure of the devfile 2.0 been fixed or is it still being debated? The link for the documentation (https://devfile.github.io/website/) provided on the kubernetes-api github page seems to be broken (https://github.com/devfile/kubernetes-api)

Appreciate any inputs!

@neeraj-laad
Copy link
Contributor Author

@jaideepr97 Sorry missed this message as the PR got merged.

  1. odo deploy flags mentions multiple ways to handle flag inputs (registry credentials etc) depending on the type of target ( k8s/OS) - is the target specified in the devfile or supplied in some other way?

The intent was to sue a fully qualified image name (registry, repo, name, version etc.) to be supplied as the --tag argument and corresponding credentials to be supplied as credentials. That said the first implementation will be using Openshift BuildConfig so we will not need tag and credentials. for that case.

  1. I understand that as of now odo deploy is intended to only be used for deployments in the dev environment. However, I was wondering, given enough time to mature through successive improvements, if there was any likelihood of configuring existing pipelines to leverage odo deploy internally to deploy applications to prod and other environments at some point down the line

It can be though, using a developer CLI tool in a pipeline was a bit odd. Instead the odo pipelines init/bootstrap will use the same code to provide appropriate build/deploy artifacts that the pipelines can use. This will allow the pipelines to be generic and not have to rely on odo.

  1. Is the intention of having a devfile that the user would not have to worry about any of the deployment details at all? Because as per my understanding the devfile points to variable resources like the deployment manifest and source URL which would probably be specific to an application and can't just be picked up by odo deploy from a stock devfile for a particular language/framework

The intent is that the devfile can provide default dockerfile/deployment manifests that will work with standard apps for that technology/framework. If the developer wants to override this, they do have the capability to do so by utilising standard inheritance and override capabilities that will be available to devfiles.

  1. Has the structure of the devfile 2.0 been fixed or is it still being debated? The link for the documentation (https://devfile.github.io/website/) provided on the kubernetes-api github page seems to be broken (https://github.com/devfile/kubernetes-api)

I would think this would be temporary. It is close to getting finalised but this feature was suggesting no changes to devfile spec. As a proper syntax and first class support will be added as part of Devfile 2.1.0

bigkevmcd pushed a commit to rhd-gitops-example/odo that referenced this pull request Jun 27, 2020
* add mik-dass and dharmit as top level approvers (redhat-developer#3189)

* Add .gitignore files for jekyll / site (redhat-developer#3171)

**What type of PR is this?**
> Uncomment only one ` /kind` line, and delete the rest.
> For example, `> /kind bug` would simply become: `/kind bug`

/kind code-refactoring

**What does does this PR do / why we need it**:

Updates the `.gitignore` for html and jekyll information. As I kept
having to `git clean` the dir.

**Which issue(s) this PR fixes**:

N/A

**How to test changes / Special notes to the reviewer**:

N/A

Signed-off-by: Charlie Drage <charlie@charliedrage.com>

* Performance improvement for odo catalog list components when using devfiles (redhat-developer#3112)

* feat: parallel fetching of component types to improve performance

Fix redhat-developer#3105 as we now also fetch devfiles for completion, which was
previously prohibitively slow.

* fix: add missing mutex, rename existing one for clarity

* refactor: simplify getDevfileWith by computing link within function

* docs: add documentation, update existing one

* refactor: rename wg to devfileWG for clarity

* fix: improper test setup

* fix: only filter components if there's no error

* fix: re-implement using channels, handle error and timeout better

* fix: no need to pass error

* fix: populate base in GetDevfileIndex, use registry URL, hiding path

* fix: properly retrieve all devfiles

Performance is not that great so investigating better options.

* fix: use new ConcurrentTasks support, allowing proper error reporting

* fix: adapt to dynamic registries

* feat: simplify ConcurrentTask by hiding WaitGroup

It was too easy to forget calling Done in ToRun leading to deadlocks.

* fix: broken tests

* fix: wording

[skip ci]

* fix: remove unused function, added doc

[skip ci]

* fix: remove unused ErrorWrapper

[skip ci]

* fix: rename package import

[skip ci]

* fix: test getDevfileIndexEntries directly, remove now unused function

* JSON output for service list in experimental mode (redhat-developer#3186)

* JSON output for service list in experimental mode

* Changes to tests as per PR feedback

redhat-developer#3186 (review)

* Adds a document for debugging applications using devfiles (redhat-developer#3187)

* Adds a document for debugging applications using devfiles

* Updated syntax and improving the wording

Signed-off-by: mik-dass <mrinald7@gmail.com>

* Actually wait for the project to be deleted.. (redhat-developer#2397)

Actually wait..

Signed-off-by: Charlie Drage <charlie@charliedrage.com>

* Run devfile docker url tests without kube config (redhat-developer#3223)

* Run devfile docker url tests without kube config

Signed-off-by: John Collier <John.J.Collier@ibm.com>

* Update target

Signed-off-by: John Collier <John.J.Collier@ibm.com>

* Fix typo

Signed-off-by: John Collier <John.J.Collier@ibm.com>

* Setting golang version uniformly accross repo and updating docs (redhat-developer#3204)

* Setting golang version uniformly accross repo and updating docs

 - All golang version references now uniformly updated to 1.12
 - Adding all golang version references to development.adoc

Signed-off-by: Mohammed Zeeshan Ahmed <mohammed.zee1000@gmail.com>

* Adding golang warning to admonition block

Signed-off-by: Mohammed Zeeshan Ahmed <mohammed.zee1000@gmail.com>

* Removing unnessasary space

Signed-off-by: Mohammed Zeeshan Ahmed <mohammed.zee1000@gmail.com>

* Adding back warning as github does not render admonition in normal view

Signed-off-by: Mohammed Zeeshan Ahmed <mohammed.zee1000@gmail.com>

* Fixing the warning to look better

Signed-off-by: Mohammed Zeeshan Ahmed <mohammed.zee1000@gmail.com>

* Fixing up the list title

Signed-off-by: Mohammed Zeeshan Ahmed <mohammed.zee1000@gmail.com>

* Fixing up admonishments

Signed-off-by: Mohammed Zeeshan Ahmed <mohammed.zee1000@gmail.com>

* Fixing commits as per @cdrage comments

Signed-off-by: Mohammed Zeeshan Ahmed <mohammed.zee1000@gmail.com>

* Fix odo describe not listing all the ports after first url is created (redhat-developer#3224)

* Fix odo describe not listing all the ports after first url is created

This PR fixes redhat-developer#3201.

Signed-off-by: Denis Golovin dgolovin@redhat.com

* update tests

Co-authored-by: Tomas Kral <tkral@redhat.com>

* Support listing devfile components with no devBuild command (redhat-developer#3172)

* Don't require devfiles to have a devBuild command

Signed-off-by: John Collier <John.J.Collier@ibm.com>

* Update integration tests

Signed-off-by: John Collier <John.J.Collier@ibm.com>

* Update integration test

Signed-off-by: John Collier <John.J.Collier@ibm.com>

* Update integration test for odo create

Signed-off-by: John Collier <John.J.Collier@ibm.com>

* Make devRun check case-insensitive

Signed-off-by: John Collier <John.J.Collier@ibm.com>

* replace secured with secure (redhat-developer#3238)

A typo existing in sample file

* Running devfile integration tests on kubernetes cluster (redhat-developer#3233)

* Document to run tests on kubernetes cluster

* Addressed review comment

* Updated the doc as per reviewer request

* Modify operator hub tests to run in separate namespaces (redhat-developer#3239)

* Modify operator hub tests to run in separate namespaces

**What type of PR is this?**
/kind cleanup
/kind failing-test

**What does does this PR do / why we need it**:
This PR ensures that each test spec for operator hub is run in a
separate namespace. This is needed because these tests were written in a
stringent fashion which tied the hands while writing additional tests
for the feature.

This PR should help take the tests out of the "odo test statistics"
dashboard.

**Which issue(s) this PR fixes**:

Fixes redhat-developer#3193

**How to test changes / Special notes to the reviewer**:
CI should pass. Specially for Operator Hub tests under
`tests/integration/operatorhub`

* Changes as per PR review

* Remove createEtcdClusterService function and more separate specs

- Removed the function because it *seemed* to be leading to race
  conditions
- Separating specs for the same reason

* Loop for two operators

* Make operator hub tests sequential

We're doing this because parallel run is causing numerous failures in CI
and local. In spite of debugging it for some time, we're not able to fix
it. However, we're on a deadline because operator hub failures are
showing up across the PRs. Hence, for time being, we're making these
tests sequential.

redhat-developer#3244

* Add devfile command flags to watch (redhat-developer#3075)

* save non default devfile cmd in env.yaml for push and watch

Signed-off-by: Maysun J Faisal <maysun.j.faisal@ibm.com>

* Add and update tests for envinfo

Signed-off-by: Maysun J Faisal <maysun.j.faisal@ibm.com>

* Update watch test to incl new watch param

Signed-off-by: Maysun J Faisal <maysun.j.faisal@ibm.com>

* watch integration test

Signed-off-by: Maysun J Faisal <maysun.j.faisal@ibm.com>

* Display msg when devfile commands are changed via odo push

Signed-off-by: Maysun J Faisal <maysun.j.faisal@ibm.com>

* Change Logic for watch flag + feedback 1

Signed-off-by: Maysun J Faisal <maysun.j.faisal@ibm.com>

* Update Watch tests with feedback

Signed-off-by: Maysun J Faisal <maysun.j.faisal@ibm.com>

* disable watch test on kube since we now use oc

Signed-off-by: Maysun J Faisal <maysun.j.faisal@ibm.com>

* Watch test feedback 2

Signed-off-by: Maysun J Faisal <maysun.j.faisal@ibm.com>

* Adding sparseCheckoutDir functionality to devfiles (redhat-developer#3042)

* Initial commit

* added devfile

* added tests

* commented out tests

* change to validpath statement

* changed method of extracting zip

* changed pathsToUnzip to pathToUnzip

* Added error message when no files are unzipped

* cleaned up conditional prefix trim

* Changes from feedback

* feedback changes and unit tests for util func

* check for empty pathToUnzip

* changed error message format

* cleaned up path separator for windows

* fixed return pathToUnzip

* use hassuffix

* moved to function

* fromslash

* minor fixes

* lowercase fix for test

* Run test locally against 4.* Cluster (redhat-developer#3218)

* Run test locally against 4.* Cluster

* Added review comments

* Added few more review comments

* Addressed review comments

* Addressed review comments

* Addressed correct format review comments

* Update samples for deploying a devfile in deploying-a-devfile-using-odo.adoc (redhat-developer#3163)

* Update devfile doc samples

[skip ci]

Signed-off-by: John Collier <John.J.Collier@ibm.com>

* Address review comments

Signed-off-by: John Collier <John.J.Collier@ibm.com>

* Fix formatting

Signed-off-by: John Collier <John.J.Collier@ibm.com>

* Replace multiple expect statement with MatchAllInOutput and DontMatchAllInOutput (redhat-developer#3251)

* Replaced multiple expect assert statement with MatchAllInOutput

* Replaced multiple expect check within same variable with MatchAllInOutput and DontMatchAllInOutput throughout the test

* Formatted string array which were exceeding 120 character

* add state to ingress list and describe (redhat-developer#3160)

* add state to ingress list and describe

Signed-off-by: Stephanie <stephanie.cao@ibm.com>

* use URL struct in url describe and list

* add unit tests

Signed-off-by: Stephanie <stephanie.cao@ibm.com>

* modify integration test and add more unit tests

Signed-off-by: Stephanie <stephanie.cao@ibm.com>

* remove types created

* address review comment

* delete removed tests

Signed-off-by: Stephanie <stephanie.cao@ibm.com>

* return error if the error is not notfound

Signed-off-by: Stephanie <stephanie.cao@ibm.com>

* list multiple ulrs in test

Signed-off-by: Stephanie <stephanie.cao@ibm.com>

* Don't prompt for namespace if pushtarget is Docker (redhat-developer#3248)

Signed-off-by: John Collier <John.J.Collier@ibm.com>

* Fix windows incompatibility with /tmp (redhat-developer#3252)

* Fix checkForImageStream to return correct result. (redhat-developer#3281)

* Add Support for Devfile V2 (redhat-developer#3216)

* Add Devfile Parser V2, Update Common Structs (redhat-developer#3188)

* Add Devfile Parser for Version 2.0.0

Added Devfile V2 Go Structures
Added converter for v2 ro common types

Signed-off-by: adisky <adsharma@redhat.com>

* Add example V2 devfile

added example nodejs V2 devfile

* Add Common Types as V2

Add common types as v2
Add Converter from common to v1

* Updated example devfile with group

* Fixes command.go and kubernetes adapter (redhat-developer#3194)

Signed-off-by: mik-dass <mrinald7@gmail.com>

* Fixes utils of k8s adapter (redhat-developer#3195)

* Update Command Logic to use groups (redhat-developer#3196)

* Updates create logic to v2 (redhat-developer#3200)

* Fixes utils of docker docker adapter (redhat-developer#3198)

Signed-off-by: mik-dass <mrinald7@gmail.com>

* Update Docker and Kubernetes adapter to use groups (redhat-developer#3206)

* Update Docker and Kubernetes adapter to use groups

* Update Some Validation

Incorporate some review comments for commands Map
Update Some Validation logic

* Updated Logs for V2 (redhat-developer#3208)

Fixed interface implementation for v2
Updated logs
refactored commands.go

* Avoid String Pointers (redhat-developer#3209)

While converting v1 to v2 types, string pointers are prone to cause
null pointer error. This PR updates struct fields from string
pointers to string

* Update commands check

* Fixes lower and upper case for commands (redhat-developer#3219)

* Fixes type of project and components for devfile v1 (redhat-developer#3228)

* Update testing utils (redhat-developer#3220)


* Update command tests

Updated Command tests to v2
Removed some cases like command type validation, that will be
validated by schema only.

* Fix common adapters tests

All devfile.adapters.common unit tests are fixed

* Add tests for Mismatched type

Fix devfile.adapters.Kubernetes.Component unit tests

* Add TestCase for default command

* Design proposal: Event notification support for build and application status for IDE integration for devfile scenarios (redhat-developer#2550) (redhat-developer#3177)

* Add event notification proposal

[skip ci]

* Update event-notification.md

* Update event-notification.md

* Update event-notification.md

* Update event-notification.md

* Update event-notification.md

* Update event-notification.md

* Update event-notification.md

* Update event-notification.md

* Fix Integration tests for devfile v2 (redhat-developer#3236)

* Fix Integration tests

Correct volume structure
Fix supervisord binary insertion for docker
Insert command and args in build container fr docker

* Fix Integration tests

Revert commands, args removal
Add commands, args in v2 common structs
Fix duplicate volume error

* Fixes unit tests (redhat-developer#3240)

Signed-off-by: mik-dass <mrinald7@gmail.com>

* Add devfiles V2 examples (redhat-developer#3253)

Add devfiles v2 examples for springboot and nodejs

* Fix regression by sparse checkout dir PR (redhat-developer#3258)

fix regression caused by rebase to master.
Also add github, zip as supported project types.

* Address review comments (redhat-developer#3267)

* Address review comments part 2

fix log levels to v4
fix error formatting
add case no's in test cases
update some comments

* Address review comments part 2

Remove validation for group

Co-authored-by: Mrinal Das <mrinald7@gmail.com>
Co-authored-by: Jonathan West <jgwest@users.noreply.github.com>

* devfile push Integration test on kubernetes cluster (redhat-developer#3041)

* Running devfile push integration test on kubernetes cluster

* Updated xenial insecure registry path

* Modifying Runner variable name to cliRunner

* Common project Create and Delete function according to the running cluster

* Added checks for CI to copy kubeconfig to temp dir

* Skipping Kubeconfig set to temporary config file for prow

* Set Kubeconfig in temporary config file on kubernetes cluster only

* Fixes Kubeconfig code sync

* Separate out function for getting cliRunner

* Release 1.2.2 of odo (redhat-developer#3294)

**What type of PR is this?**
> Uncomment only one ` /kind` line, and delete the rest.
> For example, `> /kind bug` would simply become: `/kind bug`

/kind feature

**What does does this PR do / why we need it**:

Releases 1.2.1 of odo

**Which issue(s) this PR fixes**:

N/A

**How to test changes / Special notes to the reviewer**:

N/A

Signed-off-by: Charlie Drage <charlie@charliedrage.com>

* Fixes list and describe of secure URLs for not pushed components (redhat-developer#3269)

* Don't show imagestreams error on experimental mode (redhat-developer#3265)

* Don't show imagestreams error on experimental mode

Signed-off-by: John Collier <John.J.Collier@ibm.com>

* Remove unnecessary line

Signed-off-by: John Collier <John.J.Collier@ibm.com>

* Move where error message printed

Signed-off-by: John Collier <John.J.Collier@ibm.com>

* Use %q instead

Signed-off-by: John Collier <John.J.Collier@ibm.com>

* remove openshift logo from readme (redhat-developer#3301)

* Remove unnecessary preference set (redhat-developer#3287)

* report error can't find the app (redhat-developer#2927)

* Update build/VERSION to 1.2.2 (redhat-developer#3306)

**What type of PR is this?**
> Uncomment only one ` /kind` line, and delete the rest.
> For example, `> /kind bug` would simply become: `/kind bug`

/kind feature

**What does does this PR do / why we need it**:

Updates the build version to 1.2.2

**Which issue(s) this PR fixes**:

N/A

**How to test changes / Special notes to the reviewer**:

N/A

Signed-off-by: Charlie Drage <charlie@charliedrage.com>

* Update tests to use java-openliberty (redhat-developer#3318)

* Removing install script and update other references (redhat-developer#3202)

* Removing installer scripts and references in other scripts and readme

Signed-off-by: Mohammed Zeeshan Ahmed <mohammed.zee1000@gmail.com>

* Removing installer reference from development.adoc

Signed-off-by: Mohammed Zeeshan Ahmed <mohammed.zee1000@gmail.com>

* Adding a message to installer script so as to not break it for existing users

Signed-off-by: Mohammed Zeeshan Ahmed <mohammed.zee1000@gmail.com>

* Removing unused variable which is no longer needed

Signed-off-by: Mohammed Zeeshan Ahmed <mohammed.zee1000@gmail.com>

* Removing installer again

Signed-off-by: Mohammed Zeeshan Ahmed <mohammed.zee1000@gmail.com>

* Removing unused secret directory (redhat-developer#3290)

* devfile delete Integration test on kubernetes cluster (redhat-developer#2913)

* Run devfile delete integration test on kubernetes cluster

* Adding insecure registry in Docker configuration xenial ubuntu

* Fix namespace issue for url create --now (redhat-developer#3321)

* Add --devfile flag support (redhat-developer#3118)

* feat: add --devfile flag support

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* fix: fix gosec G307 issue

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* fix: update error handling

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* style: Update help and error messages

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* fix: Improve performance of error handling

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* style: Improve error message

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* fix: Fix remove file error on Windows

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* fix: Use existing structure to handle temp file

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* refactor: improve code readability and structure

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* docs: update variable comments

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* feat: --devfile value supports http(s)

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* feat: remove --devfile for all other commands

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* feat: add new design for existing devfile support

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* test: update TestCopyFile test cases

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* test: refactor file copy util function for test

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* test: fix TestCopyFile test cases

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* test: add integration tests for existing devfile

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* fix: gosec issue

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* test: fix docker url integration tests

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* fix: context support

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* test: fix docker url integration tests

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* fix: handle edge cases and add related tests

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* refactor: separate spinner for existing devfile

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* test: fix docker watch tests

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* test: fix url tests

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* Updating travis env variable and adding docker version info (redhat-developer#3068)

* 'odo login' command should suggest 'odo project list' instead of 'odo projects' (redhat-developer#3262)

* use a more specific error message for when image is not found (redhat-developer#3322)

* use a specific error message for when image is not found

* added amit's changes

* devfile create Interation test on kubernetes cluster using travis CI (redhat-developer#2884)

* Run devfile create Interation test on kubernetes cluster

* Skipping s2i image related test on kubernetes cluster

* Updating url delete to apply `--now` on devfile (redhat-developer#3139)

* Creating a function for setting devfile path

* updating url delete to do devfile push post delete

Signed-off-by: Mohammed Zeeshan Ahmed <mohammed.zee1000@gmail.com>

* Adding URL now flag delete test

Signed-off-by: Mohammed Zeeshan Ahmed <mohammed.zee1000@gmail.com>

* Fixing missing `-f`

Signed-off-by: Mohammed Zeeshan Ahmed <mohammed.zee1000@gmail.com>

* Changing position of copyexample

Signed-off-by: Mohammed Zeeshan Ahmed <mohammed.zee1000@gmail.com>

* Merging url delete with now with create

Signed-off-by: Mohammed Zeeshan Ahmed <mohammed.zee1000@gmail.com>

* Removing old devfilepath logic

Signed-off-by: Mohammed Zeeshan Ahmed <mohammed.zee1000@gmail.com>

* Adding Devfile flag to url delete

Signed-off-by: Mohammed Zeeshan Ahmed <mohammed.zee1000@gmail.com>

* CompleteDevfilePath now happens irrespective of now

Signed-off-by: Mohammed Zeeshan Ahmed <mohammed.zee1000@gmail.com>

* list devfile components catalog in json format (redhat-developer#3264)

* list catalog in json format for devfile components

Signed-off-by: Stephanie <stephanie.cao@ibm.com>

* list devfile registries in list

* combined two list into one single list

Signed-off-by: Stephanie <stephanie.cao@ibm.com>

* add omitempty

* Fix unsafe data race in ExecuteCommand (redhat-developer#3310)

**What type of PR is this?**

/kind bug

**What does does this PR do / why we need it**:

Fixes a potential flake with regards to when writing to cmdOutput at the
same time that log.ErrorF(...) is reading from it.

**Which issue(s) this PR fixes**:

Closes redhat-developer#2828

**How to test changes / Special notes to the reviewer**:

N/A, honestly not too sure

* Fix Docker Supervisord Vol Initialization (redhat-developer#3129)

* apply stashed supervisord docker changes from PR

Signed-off-by: Maysun J Faisal <maysun.j.faisal@ibm.com>

* rebase 1 with master

Signed-off-by: Maysun J Faisal <maysun.j.faisal@ibm.com>

* Converts v1 devfiles to v2 (redhat-developer#3279)

* Converts v1 devfiles to v2

* Moves init tests to devfilesV1 folder

* Adding oc to bin path for multistage testing (redhat-developer#3351)

* Revert "Adding oc to bin path for multistage testing (redhat-developer#3351)" (redhat-developer#3360)

This reverts commit fa9f7b9.

* resolved the gosec issue failing unit tests (redhat-developer#3358)

* resolved the gosec issue failing unit tests

* resolved typo in the comment

* DRYed the code

* Warn if --app and --all-apps coexist (redhat-developer#2941)

* url list routes and ingress  (redhat-developer#3305)

* list routes and ingress

Signed-off-by: Stephanie <stephanie.cao@ibm.com>

* add unit tests

* add integration tests and describe partially works

Signed-off-by: Stephanie <stephanie.cao@ibm.com>

* finished unit test and integration for describe urls

* address review comments

Signed-off-by: Stephanie <stephanie.cao@ibm.com>

* add more unit tests

Signed-off-by: Stephanie <stephanie.cao@ibm.com>

* fix unit test failure

Signed-off-by: Stephanie <stephanie.cao@ibm.com>

* fix integration test failure

Signed-off-by: Stephanie <stephanie.cao@ibm.com>

* use ownerreference to distinguish real route vs route created from ingress

Signed-off-by: Stephanie <stephanie.cao@ibm.com>

* fix integration test

Signed-off-by: Stephanie <stephanie.cao@ibm.com>

* address review comment

Signed-off-by: Stephanie <stephanie.cao@ibm.com>

* fix a bug

Signed-off-by: Stephanie <stephanie.cao@ibm.com>

* fix a bug

Signed-off-by: Stephanie <stephanie.cao@ibm.com>

* also test secure state in url describe and list

Signed-off-by: Stephanie <stephanie.cao@ibm.com>

* try to avoid G404 error in unit test

Signed-off-by: Stephanie <stephanie.cao@ibm.com>

* Fix 'odo version' integration test. (redhat-developer#3326)

* Validate application exist before describe it (redhat-developer#3349)

* Update events (redhat-developer#3370)

**What type of PR is this?**
> Uncomment only one ` /kind` line, and delete the rest.
> For example, `> /kind bug` would simply become: `/kind bug`

/kind documentation
[skip ci]

**What does does this PR do / why we need it**:

Updates the events to list that they happened in the past

**Which issue(s) this PR fixes**:

N/A

**How to test changes / Special notes to the reviewer**:

N/A

Signed-off-by: Charlie Drage <charlie@charliedrage.com>

* Updates the v2 schema to the latest (redhat-developer#3352)

* fix: properly check that odo version contains the server URL (redhat-developer#3365)

* fix: properly check that odo version contains the server URL

Fixes redhat-developer#3342

* fix: simplify test by removing server url regexp check

* Create periodic script for odo periodic job (redhat-developer#3376)

* Adds debug command for devfiles (redhat-developer#3059)

* Adds debug command for devfiles

* Fixes comments and variable names

* Adds devfile debug test on kubernetes cluster

* Fixes adapter code for debug

Signed-off-by: mik-dass <mrinald7@gmail.com>

* Converts v1 debug test devfile to v2

* Moves container arg and command overriding to a new function

* Simplifies conditions in test

* Modifies execDevfile for kubernetes component adapter

* Simplies error checking logic in TestUpdateContainersWithSupervisord

* Removes unnecessary else if conditions

* Installs socat before running tests on kubernetes cluster

* Show error message if no registries are configured (redhat-developer#3339)

* Show error message if no registries are configured

Signed-off-by: John Collier <John.J.Collier@ibm.com>

* Clean up

Signed-off-by: John Collier <John.J.Collier@ibm.com>

* Added few supported container images to e2e image test (redhat-developer#3315)

* Fix multiple registry related issues (redhat-developer#3341)

* feat: fix registry issues

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* docs: improve error/help message

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* test: improve registry tests

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* feat: github raw url conversion support

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* test: refactor testing output format

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* test: fix breaking tests

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* refactor: add validation for raw url conversion

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* Update dependencies in glide.yaml for make to succeed in building odo binary (redhat-developer#3369)

* Execute `glide update -v` to update the dependencies

* Use ContainerJSON in place of Container struct

* Push support: Event notification support for build and application status for IDE integration for devfile scenarios (redhat-developer#3003)

* Add machine readable event logging support

* Add machine readable event logging support

* Add machine readable event logging support

* Add machine readable event logging support

* Add machine readable event logging support

* Add machine readable event logging support

* Add machine readable event logging support

* Remove --devfile

* Remove incorrect constraint

* Add odo push -o json example

* Rebase and add debug action logging to new methods

* Adding oc binary to bin path for multi stage test infra (redhat-developer#3362)

* Adding oc binary to bin path for multi stage test infra

* Added file permission locally and excluding it from docker file

* Created different dockerfile to avoid master break and proceed with multistage changes

* Update devfile log levels from 3 to 4 to be consistent (redhat-developer#3408)

Signed-off-by: Maysun J Faisal <maysun.j.faisal@ibm.com>

* Design proposal: secure registry support (redhat-developer#3329)

* docs: add secure registry design proposal

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* docs: add create component section

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* Add command design for basic auth

Signed-off-by: jingfu wang <jingfu.j.wang@ibm.com>

* Proposal for odo deploy (redhat-developer#3368)

* docs: Initial design proposal for odo deploy command

Initial design proposal for adding a odo deply command.

This is related to redhat-developer#3300

Signed-off by: Neeraj Laad <neeraj.laad@gmail.com>

* Updated future evolution

Updated future evolution

Signed-off-by: Neeraj Laad <neeraj.laad@gmail.com>

* Updates to design

Signed-off-by: Neeraj Laad <neeraj.laad@gmail.com>

* Update odo-deploy.md

* Updated metadata to attributes

Updated metadata to attributes

* Fixed formatting

Fixed formatting for yaml

* [skip ci] updated design doc

* [skip ci] made credentials flag optional

made credentials flag optional

* [skip ci] clarify the deplyment example

clarify the deplyment example

* [skip ci] Updated proposal to sue buildconfig / kaniko

* [skip ci] update attribites to metadata

* [skip ci] add `alpha.` suffix to metadata keys to indicate this is temporary

* [skip ci] Use COMPONENT_NAME  as placeholder

* Updating script path in Dockerfile for multistage test (redhat-developer#3412)

* Invalid ANSI colouring on Windows when doing devfile push (redhat-developer#3327)

* show catalog component list -o json as before if experimental mode is off (redhat-developer#3399)

Signed-off-by: Stephanie <stephanie.cao@ibm.com>

* removed deprecated and nodejs 8 images from e2e tests and README (redhat-developer#3414)

* removed deprecated and nodejs 8 images from e2e tests

* removed the unsupported images from readme and removed bucharest-gold/centos7-s2i-node from everywhere as the repo has been archived

* adjusted the table

* Update changelog script (redhat-developer#3421)

**What type of PR is this?**
> Uncomment only one ` /kind` line, and delete the rest.
> For example, `> /kind bug` would simply become: `/kind bug`

/kind code-refactoring

**What does does this PR do / why we need it**:

Updates the changelog script since we were having issues with changelog
not completing due to hitting the GitHub API limit.

**Which issue(s) this PR fixes**:

N/A

**How to test changes / Special notes to the reviewer**:

N/A

Signed-off-by: Charlie Drage <charlie@charliedrage.com>

* Release 1.2.3 (redhat-developer#3422)

**What type of PR is this?**
> Uncomment only one ` /kind` line, and delete the rest.
> For example, `> /kind bug` would simply become: `/kind bug`

/kind feature

**What does does this PR do / why we need it**:

Release 1.2.3 of odo

**Which issue(s) this PR fixes**:

N/A

**How to test changes / Special notes to the reviewer**:

N/A

Signed-off-by: Charlie Drage <charlie@charliedrage.com>

* fix 'Timeout out' typo and fix formatting (redhat-developer#3404)

* fix 'Timeout out' typo and fix formating

* fix typo

* pull changes from upstream master

* add wwhrd check execption for knative.dev/pkg/test/...

Co-authored-by: Tomas Kral <tkral@redhat.com>
Co-authored-by: Charlie Drage <charlie@charliedrage.com>
Co-authored-by: Chris Laprun <metacosm@users.noreply.github.com>
Co-authored-by: Dharmit Shah <shahdharmit@gmail.com>
Co-authored-by: Mrinal Das <mrinald7@gmail.com>
Co-authored-by: John Collier <John.J.Collier@ibm.com>
Co-authored-by: Mohammed Ahmed <mohammed.zee1000@gmail.com>
Co-authored-by: Denis Golovin <dgolovin@users.noreply.github.com>
Co-authored-by: ji chen <jichenjc@cn.ibm.com>
Co-authored-by: Priti Kumari <pkumari@redhat.com>
Co-authored-by: Maysun J Faisal <31771087+maysunfaisal@users.noreply.github.com>
Co-authored-by: CameronMcWilliam <Cameron.McWilliam@ibm.com>
Co-authored-by: Amit Rout <arout@redhat.com>
Co-authored-by: Stephanie Cao <stephanie.cao@ibm.com>
Co-authored-by: Zheng Xiao Mei <xmzheng@cn.ibm.com>
Co-authored-by: Aditi Sharma <adsharma@redhat.com>
Co-authored-by: Jonathan West <jgwest@users.noreply.github.com>
Co-authored-by: Jingfu Wang <jingfu.j.wang@ibm.com>
Co-authored-by: Devang Gaur <dgaur@redhat.com>
Co-authored-by: Girish Ramnani <gramnani@redhat.com>
Co-authored-by: Girish Ramnani <girishramnani95@gmail.com>
Co-authored-by: Neeraj Laad <neeraj.laad@gmail.com>
@EnriqueL8 EnriqueL8 mentioned this pull request Jul 2, 2020
1. `odo create <component> <mycomponent>` - This initializes odo component in the current directory.
1. Edit the project source code to develop the application.
1. `odo url create` - This stores URL information (host, port etc.) for accessing the application on the cluster (if not done already).
1. `odo push` - This runs the application source code using inner-loop instructions from devfile.
Copy link
Member

Choose a reason for hiding this comment

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

@EnriqueL8 Is odo push needed to get to odo deploy, I guess No ? :)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
approved Indicates a PR has been approved by an approver from all required OWNERS files. Required by Prow. lgtm Indicates that a PR is ready to be merged. Required by Prow. ok-to-test Indicates a non-member PR verified by an org member that is safe to test.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

None yet