Skip to content

Latest commit

 

History

History
80 lines (55 loc) · 4.56 KB

contributing.md

File metadata and controls

80 lines (55 loc) · 4.56 KB

Contributing

Fixes and enhancements are welcome, but if you are planning to do a lot of work, it is a good idea to raise an issue first to discuss it. Generally enhancements should follow the goals of the project described in the main readme:

  • Allow the version to be injected into the build
  • Derive the version only from the git repository itself
  • Do not require the version to be maintained by hand
  • Resolve the version deterministically for a given commit
  • Provide an easy mechanism for incrementing major and minor versions by developers

Getting Help

Providing a Test Case

If you are planning to open a ticket, it is extremely helpful if you can provide a test case that demonstrates the problem. This project includes a test helper than makes it very easy to create new tests with just a few lines of code.

To get started simply:

  • Ensure you have the latest version of NodeJS installed (https://nodejs.org)
  • Clone the repository, git clone https://github.com/PaulHatch/semantic-version.git or git@github.com:PaulHatch/semantic-version.git
  • Run npm install in the root of the repository to install the dependencies
  • Run npm run test to run the tests

The src/main.test.ts file contains integration tests that validate all the features of this action, to add a new test case simply add a new function to the bottom of this file.

test('Name of test goes here', async () => {
    // This method creates a test repository in your temp directory, the repo
    // object returned provides methods to interact with the repository
    const repo = createTestRepo({
        // Specify any config options you want to set, the options available can be found
        // in the src/ActionConfig.ts file
        tagPrefix: ''
    });

    // the make commit method creates a commit with the specified message, an empty file will be
    // automatically created for the commit
    repo.makeCommit('Initial Commit');

    // an optional second parameter can be used to specify the path of the file to commit,
    // which will be created if it does not exist already
    repo.makeCommit('Initial Commit', 'subdir');
    
    // the exec method runs an arbitrary command in the repository
    repo.exec('git tag 0.0.1')

    // the runAction method runs the action and returns the result
    const result = await repo.runAction();

    // finally, the use whatever assertion you want to validate the result
    expect(result.formattedVersion).toBe('0.0.1+0');
}, 15000);

This uses the Jest testing framework. Really it is generally not necessary to be very familiar with Jest, just copy the pattern of the existing tests and you should be fine.

Once you have a failing test case that demostrates the problem, you can just past it into the ticket, there is no need to create a repository unless you want to.

Providing an Example Repository

If you are not able to provide a test case, it is still very helpful to provide an example repository that demonstrates the problem. Many times people are experiencing problems with a configuration of a private repository. This is quite difficult to debug without access to the repository, if you are able to provide a public repository that demonstrates the problem it will make it much easier to debug and can eliminate a great deal of back and forth.

Forking the Project

If want to do something that does not fit with the project goals, particually if you want to include information from an outside system, it is probably best to fork the project and create your own action. One of the goals of this project starting in 5.0.0 is to be easy to fork and customize, and to that end the action has been broken into individual providers than can be replaced. All providers have been implemented using async calls specifically to support calls to external systems.

The steps of this action are:

  • Get the current commit
  • Get the last release
  • Get commits between the last release and the current commit
  • Classify the release

Additionally a few formatter provide modular behavior to these step:

  • A tag formmater is used to parse and format the version number
  • A version formatter is used to format output version string
  • A user formatter is used to format the user information in the output (JSON and CSV are provided in the default implementation)

Each one includes at least one default, but can be replaced by a custom provider by implementing the appropriate interface and updating the ConfigurationProvider to return your action instead. This should allow you to continue to merge in changes from the main project as needed with minimal conflict.