This project welcomes contributions and suggestions.
All contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit https://cla.microsoft.com.
When you submit a pull request, a CLA-bot will automatically determine whether you need to provide a CLA and decorate the PR appropriately (e.g., label, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repos using our CLA.
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.
- Access to a Kubernetes cluster.
- Clone this repository.
If you have Docker and VS Code installed on your device, you can use the VS Code Remote - Containers extension to develop inside a container that contains all of the build dependencies. To do this:
- Install the VS Code Remote - Containers extension
- Open the root folder of the repository in VS Code
- Run the
Remote-Containers: Open Folder in Container...
command in VS Code (a pop-up should also appear offering to open the folder in a container)
This will download the Development Environment container from Docker Hub and configure VS Code to run all commands and Terminals inside the container. To build Rudr, launch a new Bash Termial in VS Code and run cargo build
from the rudr directory.
- Rust 2018 Edition or newer
- Install kubectl and Helm 3. Instructions for both are in the set up doc
To build:
- Go into the main directory:
cd rudr
- Install the CRDs
kubectl apply -f charts/rudr/crds/appconfigs.yaml
kubectl apply -f charts/rudr/crds/componentinstances.yaml
kubectl apply -f charts/rudr/crds/componentschematics.yaml
kubectl apply -f charts/rudr/crds/scopes.yaml
kubectl apply -f charts/rudr/crds/traits.yaml
- Run
cargo build
- To run the server:
make run
, this will run Rudr controller locally, and use the cluster by your~/.kube/config
.
At this point, you will be running a local controller attached to the cluster to which your $KUBECONFIG
is pointing.
To get started, define some components. Components are not instantiated. They are descriptions of what things can run in your cluster.
$ kubectl apply -f examples/helloworld-python-component.yaml
component.core.oam.dev "helloworld-python-v1" created
$ kubectl get components
NAME AGE
helloworld-python-v1 14m
Next, create a new application that uses the component. In Open Application Model, which follows the 12-factor model, the application is composed of code (component) and a config. So you need to write a configuration. Examples are provided in the examples/
directory:
$ kubectl apply -f examples/first-app-config.yaml
Now you may wish to explore your cluster to see what was created:
$ kubectl get configuration,pod,svc,ingress
NAME AGE
applicationconfiguration.core.oam.dev/first-app 14s
NAME READY STATUS RESTARTS AGE
pod/first-app-helloworld-python-v1-67599b9877-lh9dr 1/1 Running 0 8s
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
service/first-app-helloworld-python-v1 ClusterIP 10.104.147.6 <none> 9999/TCP 8s
NAME HOSTS ADDRESS PORTS AGE
ingress.extensions/first-app-helloworld-python-v1-trait-ingress example.com 80 8s
To delete this, run kubectl delete configuration first-app
and it will cascade and delete all of the pieces.
Like any good open source project, we use Pull Requests (PRs) to track code changes. Please familiarize yourself with the Status labels on the labels page.
- Fork the repo, modify to address the issue.
- Link the PR to the issue.
- Submit a pull request.
- PR creation
- We more than welcome PRs that are currently in progress. They are a great way to keep track of
important work that is in-flight, but useful for others to see. If a PR is a work in progress,
it should be prefaced with "WIP: [title]" and add
Status: In Progress
will be added as a label. You should add theStatus: Review Needed
label once the PR is ready for review and remove "WIP" from the title. - It is preferred, but not required, to have a PR tied to a specific issue. There can be circumstances where if it is a quick fix then an issue might be overkill. The details provided in the PR description would suffice in this case.
- We more than welcome PRs that are currently in progress. They are a great way to keep track of
important work that is in-flight, but useful for others to see. If a PR is a work in progress,
it should be prefaced with "WIP: [title]" and add
- Triage
- The maintainer in charge of triaging will apply the proper labels for the issue. This should include at least a status label and a milestone.
- Assigning reviews
- All PRs require 1 review approval from a maintainer before being merged.
- Reviewing/Discussion
- All reviews will be completed using Github review tool.
- A "Comment" review should be used when there are questions about Rudr. This type of review does not count as approval.
- A "Changes Requested" review indicates that changes need to be made before they will be merged.
- Reviewers should update labels as needed (such as
Status: Needs rebase
). - When a review is approved, the reviewer should add
LGTM
as a comment. - Final approval is required by a designated owner (see
.github/CODEOWNERS
file). Merging is blocked without this final approval. Approvers will factor reviews from all other reviewers into their approval process.
- PR owner should try to be responsive to comments by answering questions or changing text. Once all comments have been addressed,
the PR is ready to be merged. When it gets merged, the
Status: Completed
will be added signifying that it is in the next release candidate. - Merge or close
- A PR should stay open until a Final Approver (see above) has marked the PR approved
- PRs can be closed by the author without merging
- PRs may be closed by a Final Approver if the decision is made that the PR is not going to be merged
There are more ways to contribute to open source projects than pull requests. We implore users to open issues with any suggestions or problems discovered. Issues are used as the primary method for tracking work in the milestones on the project.
To learn about issue types, please read the labels page.
The issue lifecycle is mainly driven by the core maintainers, but is good information for those contributing to Rudr. All issue types follow the same general lifecycle.
- Issue creation.
- Triage
- The maintainer in charge of triaging will apply the proper labels for the issue. This includes labels for type, projects/milestones and metadata.
- (If needed) Clean up the title to succinctly and clearly state the issue. Also ensure that proposals are prefaced with "Proposal".
- We attempt to do this process at least once per work day.
- Discussion
- Enhancement, bug and document issues should be connected to the PR that resolves it.
- Whoever is working on an issue should claim the issue in the comments.
- Issues should stay open until a maintainer closes it or the owner of the issue decides to close it.
- Issue closure.
To get an overview of the milestones that are being tracked for Rudr please visit the Milestones page.
Each day, someone from a Open Application Model related team should act as the triager. This person will be in charge triaging new PRs and issues throughout the day. Anyone can volunteer as the triager by posting on the Slack channel or volunteering in advance during our community calls. If no one has volunteered by 10:00 AM PST, someone from our team will triage.
Broader discussion of any issues can be raised during the bi-weekly community call. Issues might be brought into milestones, removed from milestones or moved between milestones during the call.