diff --git a/libs/core/src/types/devfile-spec.ts b/libs/core/src/types/devfile-spec.ts index 4989b9f3..19f9ae9d 100644 --- a/libs/core/src/types/devfile-spec.ts +++ b/libs/core/src/types/devfile-spec.ts @@ -221,9 +221,12 @@ export interface PurpleExec { */ group?: TentacledGroup; /** - * Whether the command is capable to reload itself when source code changes. If set to - * `true` the command won't be restarted and it is expected to handle file changes on its - * own. + * Specify whether the command is restarted or not when the source code changes. If set to + * `true` the command won't be restarted. A *hotReloadCapable* `run` or `debug` command is + * expected to handle file changes on its own and won't be restarted. A *hotReloadCapable* + * `build` command is expected to be executed only once and won't be executed again. This + * field is taken into account only for commands `build`, `run` and `debug` with `isDefault` + * set to `true`. * * Default value is `false` */ @@ -1104,9 +1107,12 @@ export interface FluffyExec { */ group?: IndecentGroup; /** - * Whether the command is capable to reload itself when source code changes. If set to - * `true` the command won't be restarted and it is expected to handle file changes on its - * own. + * Specify whether the command is restarted or not when the source code changes. If set to + * `true` the command won't be restarted. A *hotReloadCapable* `run` or `debug` command is + * expected to handle file changes on its own and won't be restarted. A *hotReloadCapable* + * `build` command is expected to be executed only once and won't be executed again. This + * field is taken into account only for commands `build`, `run` and `debug` with `isDefault` + * set to `true`. * * Default value is `false` */ diff --git a/libs/docs/src/docs/no-version/application-developer.md b/libs/docs/src/docs/no-version/application-developer.md index 6f9eadc6..45a404ab 100644 --- a/libs/docs/src/docs/no-version/application-developer.md +++ b/libs/docs/src/docs/no-version/application-developer.md @@ -28,3 +28,7 @@ The inner-loop and outer-loop instructions defined in the devfile allow you to t - [API reference](./devfile-schema) - [Community registry viewer](https://registry.devfile.io/viewer) + +- [Quick start with odo v3](./quickstart-odo) + +- [Quick start with Eclipse Che](./quickstart-che) diff --git a/libs/docs/src/docs/no-version/developing-with-devfiles.md b/libs/docs/src/docs/no-version/developing-with-devfiles.md index c4bc003f..650c3900 100644 --- a/libs/docs/src/docs/no-version/developing-with-devfiles.md +++ b/libs/docs/src/docs/no-version/developing-with-devfiles.md @@ -15,20 +15,15 @@ To get a better understanding of what devfiles can help build, take a look at a - Use the devfile specification to develop a Node.js “Hello World” application using `odo`. Developing this application introduces you to how a devfile automates and simplifies your development process. - -Get started with [odo](https://odo.dev/docs/user-guides/quickstart/nodejs). - + - [Quick start with odo v3](./quickstart-odo) + - Get started with [odo](https://odo.dev/docs/user-guides/quickstart/nodejs). - Create a workspace in `Eclipse Che` with a community sample backed by the devfile specification to start building your application in the language of your choice. - -Get started with [Eclipse Che](https://www.eclipse.org/che/). - + - [Quick start with Eclipse Che](./quickstart-che) + - Get started with [Eclipse Che](https://www.eclipse.org/che/). - Use blueprints in `Amazon CodeCatalyst` to quickly build a "Modern three-tier web application". Start working on the source code with a Dev Environment that uses a devfile to pre-determine and install the required project tools and application libraries. - -Get started with [Amazon CodeCatalyst](https://docs.aws.amazon.com/codecatalyst/latest/userguide/getting-started-template-project.html). - + - Get started with [Amazon CodeCatalyst](https://docs.aws.amazon.com/codecatalyst/latest/userguide/getting-started-template-project.html). - Set up a remote development environment that links to your Git repository using `JetBrains Space Cloud Dev` and the devfile specification. - -Get started with [JetBrains Space Cloud Dev Environments](https://blog.jetbrains.com/space/2022/10/26/get-started-with-space-dev-environments/). + - Get started with [JetBrains Space Cloud Dev Environments](https://blog.jetbrains.com/space/2022/10/26/get-started-with-space-dev-environments/). ## Tools that provide devfile support diff --git a/libs/docs/src/docs/no-version/enterprise-architect-and-runtime-provider.md b/libs/docs/src/docs/no-version/enterprise-architect-and-runtime-provider.md index 4f1eeba0..b01e312c 100644 --- a/libs/docs/src/docs/no-version/enterprise-architect-and-runtime-provider.md +++ b/libs/docs/src/docs/no-version/enterprise-architect-and-runtime-provider.md @@ -25,6 +25,10 @@ Add the necessary policy settings and compliance policies as part of the devfile - [Overview](./overview) +- [Quick start with odo v3](./quickstart-odo) + +- [Quick start with Eclipse Che](./quickstart-che) + - [Onboarding process and requirements of the community registry](https://github.com/devfile/registry/blob/main/CONTRIBUTING.md) - [Community registry viewer](https://registry.devfile.io/viewer) diff --git a/libs/docs/src/docs/no-version/quickstart-che.md b/libs/docs/src/docs/no-version/quickstart-che.md new file mode 100644 index 00000000..e51fd9b0 --- /dev/null +++ b/libs/docs/src/docs/no-version/quickstart-che.md @@ -0,0 +1,209 @@ +--- +title: "Quick start with Eclipse Che" +description: "Quick start with Eclipse Che" +--- + +This guide will run through creating a simple hello world devfile project using Eclipse Che. The purpose of this guide is to provide a practical introduction to those just starting out with devfiles. + +## Prerequisites + +- Eclipse Che 7.65.x +- `kubectl` or `oc` +- Access to a Kubernetes or OpenShift cluster + +## Procedure + +1. Obtain access to Eclipse Che if you do not already have it, as an individual this can be done by setting up a [local instance of Eclipse Che](https://www.eclipse.org/che/docs/stable/administration-guide/installing-che-locally/) + - You can use `minikube` to run your cluster locally, follow [these](https://minikube.sigs.k8s.io/docs/start/) steps to get started + - An alternative is to use the [Eclipse Che hosted by Red Hat](https://developers.redhat.com/developer-sandbox/ide), see + [the corresponding guide](https://www.eclipse.org/che/docs/stable/hosted-che/hosted-che/) in Eclipse Che documentation if this method is used + +2. For this quick start guide, we will create a simple [hello world Express.js](https://expressjs.com/en/starter/hello-world.html) application + +3. In Eclipse Che, create an empty workspace + +4. Create the files which make up the simple [hello world Express.js](https://expressjs.com/en/starter/hello-world.html) application + + ```json {% title="package.json file" filename="package.json" %} + { + "name": "helloworld-devfile", + "version": "1.0.0", + "description": "", + "main": "app.js", + "type": "module", + "dependencies": { + "@types/express": "^4.17.17", + "express": "^4.18.2" + } + } + ``` + + ```js {% title="Application source code" filename="app.js" %} + import express from "express" + + const PORT = 3000 + const app = express() + + app.get("/", (req, res) => { + res.send("Hello world!") + }) + + app.listen(PORT, () => { + console.log(`Listening on port ${PORT}..`) + }) + ``` + +5. Create a devfile with the filename `.devfile.yaml`. The devfile should be populated with content similar to the following + - The `schemaVersion` of the devfile can to set to the desired devfile specification version to use + - It is recommended to use the latest release, currently `2.2.0` + - The `metadata.name` field is the name of the workspace for the project + + ```yaml {% filename=".devfile.yaml" %} + schemaVersion: + metadata: + name: helloworld-example + ``` + +6. Next, create the first component to serve as the dev environment for the project, for this use the [`container`](./devfile-schema#components-container) component with the name `dev-tooling` and the `quay.io/devfile/universal-developer-image:latest` image + - `name` is the identifier used to refer to the component + - `image` is the container image to use for the component, `quay.io/devfile/universal-developer-image` is the default development tooling image used by Eclipse Che with multiple programming languages supports (including Node.js). + + ```diff {% filename=".devfile.yaml" %} + schemaVersion: + metadata: + name: helloworld-example + +components: + + - name: dev-tooling + + container: + + image: quay.io/devfile/universal-developer-image:ubi8-latest + ``` + +7. The `dev-tooling` container will host the expressjs app which listens on port `3000`, define this port in the component by specifying an entry +under [`endpoints`](./devfile-schema#components-container-endpoints) + - Each endpoint has at least a `name` to identify them and the `targetPort` to specify the port number to forward + + ```diff {% filename=".devfile.yaml" %} + schemaVersion: + metadata: + name: helloworld-example + components: + - name: dev-tooling + container: + image: quay.io/devfile/universal-developer-image:ubi8-latest + + endpoints: + + - name: http-3000 + + targetPort: 3000 + ``` + +8. Now that the `dev-tooling` container is defined, [`commands`](./devfile-schema#commands) are useful to add in the IDE (the default is VS Code) some UI elements to guide developers during the development cycle. Define the command to install the dependencies needed to run the application (`npm install`) + - The `id` field identifies the command so that it can be referenced in events or composite commands. + - An [`exec`](./devfile-schema#commands-exec) command specifies explicit shell command(s) to run on a given `component` + - `commandLine` defines the shell command(s) to execute as part of that devfile command + - The `group` specifies what `kind` of command it is or if it is the default of its kind, `isDefault` + + ```yaml {% title="Install command" %} + commands: + - id: install + exec: + commandLine: npm install + component: dev-tooling + workingDir: ${PROJECT_SOURCE} + group: + isDefault: true + kind: build + ``` + +9. Next, define the command to run the application (`node app.js`) + + ```yaml {% title="Run command" %} + commands: + - id: run + exec: + commandLine: node app.js + component: dev-tooling + workingDir: ${PROJECT_SOURCE} + group: + isDefault: true + kind: run + ``` + +10. Now the devfile is ready to be used to run the application with Eclipse Che + + ```yaml {% title="Complete Workspace Devfile" filename=".devfile.yaml" %} + schemaVersion: + metadata: + name: helloworld-example + components: + - name: dev-tooling + container: + image: quay.io/devfile/universal-developer-image:ubi8-latest + endpoints: + - name: http-3000 + targetPort: 3000 + commands: + - id: install + exec: + commandLine: npm install + component: dev-tooling + workingDir: ${PROJECT_SOURCE} + group: + isDefault: true + kind: build + - id: run + exec: + commandLine: node app.js + component: dev-tooling + workingDir: ${PROJECT_SOURCE} + group: + isDefault: true + kind: run + ``` + +11. Click 'Eclipse Che' in the bottom left corner, then select 'Eclipse Che: Restart Workspace from Local Devfile' to reload the workspace +with the new devfile + +12. Once the workspace has finished restarting, run the `install` command by opening the menu, open 'Terminal/Run Task', under the 'Run Task' menu open 'devfile/devfile: install', the task should open +a terminal with the following + + ``` {% title="Output of running the 'install' command in Che" %} + * Executing task: devfile: install + + + added 67 packages, and audited 68 packages in 8s + + 7 packages are looking for funding + run `npm fund` for details + + found 0 vulnerabilities + npm notice + npm notice New major version of npm available! 8.3.1 -> 9.6.5 + npm notice Changelog: https://github.com/npm/cli/releases/tag/v9.6.5 + npm notice Run npm install -g npm@9.6.5 to update! + npm notice + * Terminal will be reused by tasks, press any key to close it. + ``` + +13. Run the application with the `run` command by going through the same steps as `install` but under the 'Run Task' menu open 'devfile/devfile: run', the task should open + - The `run` command will execute until the user interrupts it, such as killing it with *Ctrl-C* + + ``` {% title="Output of running the 'run' command in Che" %} + * Executing task: devfile: run + + Listening on port 3000.. + ``` + +14. Under the 'EXPLORER', expand the 'ENDPOINTS' panel and copy the `http-3000` endpoint URL + +15. Paste the endpoint URL in a new tab and the response should just show "Hello World!" + +16. (Optional) Normally when creating a workspace it is recommended to use a sample under 'Select a Sample' from the embedded devfile registry to +start your project, a similar devfile project workspace can be created using the 'Node.js Express Web Application' sample + +17. Congratulations! You have written your first devfile project with Eclipse Che! + +## Additional Resources + +- [Devfile Schema](./devfile-schema) +- [Adding components](./adding-components) +- [Adding commands](./adding-commands) +- [Eclipse Che docs](https://www.eclipse.org/che/docs/stable/overview/introduction-to-eclipse-che/) diff --git a/libs/docs/src/docs/no-version/quickstart-odo.md b/libs/docs/src/docs/no-version/quickstart-odo.md new file mode 100644 index 00000000..9ebc7578 --- /dev/null +++ b/libs/docs/src/docs/no-version/quickstart-odo.md @@ -0,0 +1,224 @@ +--- +title: "Quick start with odo v3" +description: "Quick start with odo v3" +--- + +This guide will run through creating a simple hello world devfile project using `odo` version 3. The purpose of this guide is to provide a practical introduction to those just starting out with devfiles. + +## Prerequisites + +- `odo` v3 +- Access to a Kubernetes or OpenShift cluster + +## Procedure + +1. Access or setup your target cluster + - (Optional) You can use `minikube` to run your cluster locally, follow [these](https://minikube.sigs.k8s.io/docs/start/) steps to get started + +2. Install `odo` version 3 if you do not already have it by following the [Installation guide](https://odo.dev/docs/overview/installation) + +3. Once installed, use `odo login` to login with your cluster credentials + - This step is not needed if using `minikube` + +4. Create a directory to store a simple [hello world Express.js](https://expressjs.com/en/starter/hello-world.html) application + + ```json {% title="package.json file" filename="package.json" %} + { + "name": "helloworld-example", + "version": "1.0.0", + "description": "", + "main": "app.js", + "type": "module", + "dependencies": { + "@types/express": "^4.17.17", + "express": "^4.18.2" + }, + "scripts": { + "start": "node app.js" + } + } + ``` + + ```js {% title="Application source code" filename="app.js" %} + import express from "express" + + const PORT = 3000 + const app = express() + + app.get("/", (req, res) => { + res.send("Hello world!") + }) + + app.listen(PORT, () => { + console.log(`Listening on port ${PORT}..`) + }) + ``` + +5. (Optional) Normally it is recommended to use `odo init` to start your project from a devfile registry stack, see [Developing with Node.JS](https://odo.dev/docs/user-guides/quickstart/nodejs#step-2-initializing-your-application-odo-init) and [Command Reference: odo init](https://odo.dev/docs/command-reference/init) for details, steps 6-11 will go through the process of making the devfile from scratch + - For this project, run `odo init --name helloworld-example --devfile nodejs`, to test this devfile in action, skip to step 12 + +6. Create a devfile with the filename `.devfile.yaml`. Add the [`schemaVersion`](./devfile-schema#schema-version) field with the desired devfile specification version to use + + ```yaml {% filename=".devfile.yaml" %} + schemaVersion: + ``` + +7. Next, create the first component to serve as the runtime for the project, for this use the [`container`](./devfile-schema#components-container) component with the name `runtime` and the `node:18-alpine` image + - `name` is the identifier used to refer to the component + - `image` is the container image to use for the component + + ```diff {% filename=".devfile.yaml" %} + schemaVersion: + +components: + + - name: runtime + + container: + + image: node:18-alpine + ``` + +8. The `runtime` container hosts the expressjs app created which listens on port `3000`, define this port in the component by specifying an entry under [`endpoints`](./devfile-schema#components-container-endpoints) + - Each endpoint has at least a `name` to identify them and the `targetPort` to specify the port number to forward + + ```diff {% filename=".devfile.yaml" %} + schemaVersion: + components: + - name: runtime + container: + image: node:18-alpine + + endpoints: + + - name: http-3000 + + targetPort: 3000 + ``` + +9. Now that the `runtime` container is defined, [`commands`](./devfile-schema#commands) are needed to tell `odo` what to do during the step of the [development runtime](https://odo.dev/docs/overview/dev_and_deploy#when-should-i-use-odo-dev) (`odo dev`). Define the command to install the dependencies needed to run the application (`npm install`) + - The `id` field identifies the command by a label which can be used to specify which command to run by the dev tool + - Example: `odo dev --build-command install` + - An [`exec`](./devfile-schema#commands-exec) command specifies explicit shell command(s) to run on a given `component` + - `commandLine` defines the shell command(s) to execute as part of that devfile command + - The `group` specifies what `kind` of command it is or if it is the default of its kind, `isDefault` + - `build` commands runs before `run` commands + + ```diff {% filename=".devfile.yaml" %} + schemaVersion: + components: + - name: runtime + container: + image: node:18-alpine + endpoints: + - name: http-3000 + targetPort: 3000 + +commands: + + - id: install + + exec: + + commandLine: npm install + + component: runtime + + workingDir: ${PROJECT_SOURCE} + + group: + + isDefault: true + + kind: build + ``` + +10. Next, define the command to run the application (`node app.js`) + + ```diff {% filename=".devfile.yaml" %} + schemaVersion: + components: + - name: runtime + container: + image: node:18-alpine + endpoints: + - name: http-3000 + targetPort: 3000 + commands: + - id: install + exec: + commandLine: npm install + component: runtime + workingDir: ${PROJECT_SOURCE} + group: + isDefault: true + kind: build + + - id: run + + exec: + + commandLine: node app.js + + component: runtime + + workingDir: ${PROJECT_SOURCE} + + group: + + isDefault: true + + kind: run + ``` + +11. Now the devfile is ready to be used to run the application + + ```yaml {% title="Devfile for Hello World application" filename=".devfile.yaml" %} + schemaVersion: + components: + - name: runtime + container: + image: node:18-alpine + endpoints: + - name: http-3000 + targetPort: 3000 + commands: + - id: install + exec: + commandLine: npm install + component: runtime + workingDir: ${PROJECT_SOURCE} + group: + isDefault: true + kind: build + - id: run + exec: + commandLine: node app.js + component: runtime + workingDir: ${PROJECT_SOURCE} + group: + isDefault: true + kind: run + ``` + +12. Run `odo dev` and you should see the following output + + ``` {% title="odo dev output" %} + __ + / \__ Developing using the "helloworld-devfile" Devfile + \__/ \ Namespace: default + / \__/ odo version: v3.9.0 + \__/ + + ⚠ You are using "default" namespace, odo may not work as expected in the default namespace. + ⚠ You may set a new namespace by running `odo create namespace `, or set an existing one by running `odo set namespace ` + + ↪ Running on the cluster in Dev mode + • Waiting for Kubernetes resources ... + ⚠ Pod is Pending + ✓ Pod is Running + ✓ Syncing files into the container [401ms] + ✓ Building your application in container (command: install) [1s] + • Executing the application (command: run) ... + - Forwarding from 127.0.0.1:20001 -> 3000 + + + ↪ Dev mode + Status: + Watching for changes in the current directory /path/to/project + + Keyboard Commands: + [Ctrl+c] - Exit and delete resources from the cluster + [p] - Manually apply local changes to the application on the cluster + ``` + +13. The application port `3000` served in the cluster gets routed to your host on a different port (in this case `20001`). Run `curl http://localhost:20001` and you should see the following output + + ``` {% title="Response content returned by curl" %} + Hello world!% + ``` + +14. Congratulations! You have written your first devfile project with `odo`! + +## Additional Resources + +- [Devfile Schema](./devfile-schema) +- [Adding components](./adding-components) +- [Adding commands](./adding-commands) +- [odo docs](https://odo.dev/docs/introduction) \ No newline at end of file diff --git a/libs/docs/src/navigation/no-version.yaml b/libs/docs/src/navigation/no-version.yaml index be100ece..081e5a6f 100644 --- a/libs/docs/src/navigation/no-version.yaml +++ b/libs/docs/src/navigation/no-version.yaml @@ -23,6 +23,10 @@ top: href: ./devfile-ecosystem - title: Get started links: + - title: "Quick start with odo v3" + href: ./quickstart-odo + - title: "Quick start with Eclipse Che" + href: ./quickstart-che - title: Developing with devfiles href: ./developing-with-devfiles - title: Integrate with editors