Skip to content

Files

Latest commit

 

History

History
70 lines (45 loc) · 3.27 KB

README.md

File metadata and controls

70 lines (45 loc) · 3.27 KB

Development guidelines

⚠️ Work in progress ⚠️

Definition of Done

  • The issue should describe briefly the feature. It should help others know that it aims to accomplish and which it's the feature scope
  • Implementation follows the code style guidelines
  • Implementation has the proper testing. Unit tests are usually enough, but some cases might require integration tests.
  • Documentation

Code style

General

  • Use meaningful names. Be verbose where it increases clarity.
  • Use Google Java Style. IntellJ has a plugin that auto formats using Google Java Style.

Visibility of Variables and Methods

  • public is used for any method that must have scope to any client code that lives in different packages. This is true of Action::Action(...) because dependent applications must be able to access this constructor from any proprietary (customer/client) package.

  • protected is used only for extending subclass of a given superclass. Currently in Action we don't allow extension, so there are no protected methods.

  • package (default) is highly necessary for libraries, allowing access to behaviors and state that may be gained only by other library components located in the same package. Various top-level vlingo-platform components use this because they are ultimately libraries and require "secret" access to internal behaviors and data.

  • private is used when no other component outside the declaring class may access a method or data, not even extending subclasses or package-related classes.

Variables declaration

  • Prefer Immutability. Use final always unless you do need make mutable state for a good reason.

Branches convention

Usually, a branch is because of a new feature or bug fix related to a specific issue. The branch name should help others know what they will find in it.

  • Bug fix: fix/<ISSUE_NUMBER>/<short description>
  • Feature/Task: task/<ISSUE_NUMBER>/<short description>

With this schema, people could find the issue related to the branch + all the explanation.

Pull Request

  • A Pull Request must only solve one issue.
  • It should refer the issue in the title.
  • Ask the component responsible for a review + all people you think it might interest it
  • In case there's something of the Definition of Done still pending, add a comment in the Pull Request to help the reviewer.

Copyright

Add the next copyright text on top of each Source File.

// Copyright © 2012-2018 Vaughn Vernon. All rights reserved.
//
// This Source Code Form is subject to the terms of the
// Mozilla Public License, v. 2.0. If a copy of the MPL
// was not distributed with this file, You can obtain
// one at https://mozilla.org/MPL/2.0/.

Configure your IDE to autoinclude the copyright