Skip to content

Latest commit

 

History

History
77 lines (66 loc) · 3.67 KB

DEVEL.md

File metadata and controls

77 lines (66 loc) · 3.67 KB

Code Review Guidelines

When doing code reviews, here are some things to be considered.

  • Normal design/code quality/style things
  • Do any changes need to be reflected in docs?
  • Were the appropriate system tests run?
  • Do the appropriate unit tests exist?
  • Is this a backwards-compatible change; Which branches should it go into?

Golang Development Guidelines

  • Unit test all public interfaces.
  • Format code according to the go standards.
  • Setup your preferred editor to 'go fmt' on save - non-formatted code will not be accepted for merge.
  • Setup your preferred editor to 'go lint' on save
  • We highly recommend using 'go vet'
  • Familiarize yourself with and adhere to these additional coding standards.
  • Adhere to these Container Connector specific standards:
    • Use struct{} as a sentinel value, rather than bool or interface{}. For example, a set is map[string]struct{}; a signal channel is chan struct{}. It unambiguously signals an explicit lack of information.
    • Go does not limit line lengths, lines of extreme length can become problematic and hard to read: https://github.com/golang/go/wiki/CodeReviewComments#line-length. Break long lines on parameters:
    func process(
          dst io.Writer,
          readTimeout,
          writeTimeout time.Duration,
          allowInvalid bool,
          max int,
          src <-chan util.Job,
      ) {
          // ...
      }
    
    • When constructing objects pass members as part of the initialization:
    f := foo.New(foo.Config{

          Site: "zombo.com",

          Out:  os.Stdout,

          Dest: conference.KeyPair{

              Key:   "gophercon",
              Value: 2014,
          },
    })
    

Managing vendors

Dependencies are managed with godep. For details, see https://github.com/tools/godep

If you just want to build, or make changes that don't affect dependencies, there is nothing special to do.

If your change to modify dependencies, you will need to deal with godep. In general, you will want to:

  1. make godep-restore - This will install all your dependencies into $GOPATH, and remove the vendor directory. go build will find the versions of the dependencies in $GOPATH, allowing you to easily modify them
  2. Hack. install/upgrade deps with go get. Build/test locally with make all test
  3. make godep-save - Save the dependencies that are used by the project.
  4. Git diff Godeps/Godeps.json to see what the dependency changes were, to make sure they are expected.
  5. git add vendor; git commit - Commit the new vendored versions as its own commit.

Gotchas

When building locally, go will find dependencies first in vendor, then in $GOPATH/src. This may cause issues because packages in vendor and $GOPATH are different. If this happens, you might see errors like this:

pkg/aspen/controller.go:127: cannot use a.clientset (type *"aspen/vendor/k8s.io/client-go/kubernetes".Clientset) as type "k8s.io/client-go/kubernetes".Interface in argument to informers.NewSharedInformerFactory:
    *"aspen/vendor/k8s.io/client-go/kubernetes".Clientset does not implement "k8s.io/client-go/kubernetes".Interface (wrong type for Apps method)
        have Apps() "aspen/vendor/k8s.io/client-go/kubernetes/typed/apps/v1beta1".AppsV1beta1Interface
        want Apps() "k8s.io/client-go/kubernetes/typed/apps/v1beta1".AppsV1beta1Interface

Here a new dependency was added to the code, and added to GOPATH, but the vendor directory wasn't removed. That new dependency also imported k8s.io/client-go/kubernetes/typed/apps/v1beta1, but since that package wasn't in vendor it satisfied that import with the version of the package that was in $GOPATH.