Adding projects to a devfile
This section describes how to add one or more projects to a devfile.
-
Add a
projectssection in the devfile, containing a list of one or more projects.Example 1. A minimal devfile with one single projectschemaVersion: 2.0.0 metadata: name: petclinic-dev-environment projects: - name: petclinic git: remotes: origin: 'https://github.com/spring-projects/spring-petclinic.git' checkoutFrom: revision: masterExample 2. A devfile with multiple projectsschemaVersion: 2.0.0 metadata: name: example-devfile projects: - name: frontend git: remotes: origin: https://github.com/acmecorp/frontend.git - name: backend git: remotes: origin: https://github.com/acmecorp/backend.git -
For each project, define an unique value for the mandatory
nameattribute. -
For each project, define a mandatory source of one of the following types:
git,githubandzip.git-
Projects with sources in Git.
Example 3. Project-source type: gitprojects: - name: my-project1 git: remotes: origin: "https://github.com/my-org/project1.git" checkoutFrom: revision: master (1) tag: 7.2.0 commitId: 36fe587 branch: master1 startPointis the general value fortag,commitId, andbranch. ThestartPoint,tag,commitId, andbranchparameters are mutually exclusive. When more than one is supplied, the following order is used:startPoint,tag,commitId,branch. github-
Same as
gitbut for projects hosted on GitHub only. Usegitfor projects that do not use GitHub-specific features. zip-
Projects with sources in a ZIP archive. Location points to a ZIP file.
Example 4. Project-source type: zipsource: zip: location: http://host.net/path/project-src.zip
-
For each project, define the optional
clonePathattribute to specify the path into which the project is to be cloned. The path must be relative to the/projects/directory, and it cannot leave the/projects/directory. The default value is the project name.Example 5. Defining theclonePathattributeschemaVersion: 2.0.0 metadata: name: my-project-dev projects: - name: my-project-resource clonePath: resources/my-project zip: location: http://host.net/path/project-res.zip - name: my-project2 git: remotes: origin: "https://github.com/my-org/project2.git" checkoutFrom: revision: develop -
For each project, define the optional
sparseCheckoutDirattribute to populate the project sparsely with selected directories.-
Set to
/my-module/to create only the rootmy-moduledirectory (and its content). -
Omit the leading slash (
my-module/) to create allmy-moduledirectories that exist in the project. Including, for example,/addons/my-module/.The trailing slash indicates that only directories with the given name (including their content) are created.
-
Use wildcards to specify more than one directory name. For example, setting
module-*checks out all directories of the given project that start withmodule-.
For more information, see Sparse checkout in Git documentation.
-