Skip to content

Latest commit

 

History

History
203 lines (148 loc) · 6.73 KB

CONTRIBUTING.md

File metadata and controls

203 lines (148 loc) · 6.73 KB

Hello Contributors!

Thanks for your interest! We're so glad you're here. Thanks for helping make Tinkerbell better 😍!

There are many areas we can use contributions - ranging from code, documentation, feature proposals, issue triage, samples, and content creation.

First, please read and understand the code of conduct found here. By participating, you're expected to uphold this code.

Table of Contents

Choose something to work on

There are multiple repositories within the Tinkerbell organization. Each repository has beginner-friendly issues that are a great place to get started on your contributor journey. For example, a list of issues for Tink repository can be found here. If there is something that you find interesting and would like to work on, go ahead. You can filter issues with label "good first issue", which are relatively self sufficient issues and great for first time contributors.

  • If you are going to pick up an issue, it would be good to add a comment stating the intention.
  • If the contribution is a big change/new feature, please raise an issue and discuss the needs, design in the issue in detail.

Get help

Do reach out on Slack or Twitter and we are happy to help.

Contributing

File an issue

Not ready to contribute code, but see something that needs work? While the community encourages everyone to contribute code, it is also appreciated when someone reports an issue. Issues should be filed under the appropriate Tinkerbell subrepository. For example, a documentation issue should be opened in tinkerbell/tinkerbell-docs. Make sure to adhere to the prompted submission guidelines while opening an issue.

Submit a change

All submissions are more than welcome. There are multiple repositories within the Tinkerbell organization. Before you submit a change, you must fork the repository and submit a pull request with the change(s). Please ensure that you adhere to the prompted submission guidelines while raising a pull request. We will try to review and provide feedback as soon as possible.

DCO Sign Off

Please read and understand the DCO found here.

Environment Details

Building is handled by make, please see the Makefile for available targets.

Nix

This repo's build environment can be reproduced using nix.

Install Nix

Follow the Nix installation guide to setup Nix on your box.

Load Dependencies

Loading build dependencies is as simple as running nix-shell or using lorri. If you have direnv installed the included .envrc will make that step automatic.

Code Style Guide

Protobuf

Please ensure protobuf related files are generated along with any change to a protobuf file. In the future CI will enforce this, but for the time being does not. Handling of protobuf deps and generating the go files are both handled by the protoc.sh script. Both go, and protoc are required by protoc.sh.

Unit Tests

One must support their proposed changes with unit tests. As you submit a pull request(PR) the CI generates a code coverage report. It will help you identify parts of the code that are not yet covered in unit tests.

Go

Import Groups

There should be two groups of import blocks, one for stdlib and the other for everything else.

Understanding code structure

This is a nonexhaustive list important packages that happen to cover most of the code base.

cmd

The cmd package is home for three core binaries for Tinkerbell:

  • tink-cli - the CLI for interacting with the tink-server
  • tink-server - the tink API server
  • tink-worker - responsible for executing the workload
.
├── cmd
│   ├── tink-cli
│   │   └── cmd
│   │       ├── delete
│   │       ├── get
│   │       ├── hardware
│   │       ├── template
│   │       └── workflow
│   ├── tink-server
│   └── tink-worker
│       ├── cmd
│       └── internal

db

The db holds everything you need to deal with the database. We use PostgreSQL as the data store. The package contains database migrations, and an API to interact with database.

.
├── db
│   ├── migration
│   ├── mock
│   └── testdata

deploy

The deploy directory contains all the essentials to setup Tinkerbell stack. You can setup a local stack with docker-compose or Vagrant.

.
├── deploy
│   ├── db
│   ├── registry
│   ├── tls
│   └── vagrant
│       └── scripts

grpc-server

The grpc-server exposes a gRPC API that connects everything together. It has a base server that implements the API.

.
├── grpc-server
│   ├── grpc_server.go
│   ├── hardware.go
│   ├── hardware_test.go
│   ├── template.go
│   ├── template_test.go
│   ├── tinkerbell.go
│   ├── tinkerbell_test.go
│   ├── workflow.go
│   └── workflow_test.go

protos

The protos package contains all the protobuf files used by the gRPC server. Handling of protobuf deps and generating the go files are both handled buf via make pbfiles. The protubuf/grpc files are not generated as part of the build pipeline to keep builds fast. CI will ensure generated files are up to date.

.
├── protos
│   ├── hardware
│   ├── packet
│   ├── template
│   └── workflow

environment variables

Tink Server, CLI, and Worker environment variables are documented here.