Skip to content

Latest commit

 

History

History
175 lines (120 loc) · 5.66 KB

DEVELOPMENT.md

File metadata and controls

175 lines (120 loc) · 5.66 KB

Development Guide

We are so glad you are interested in building Time to Leave! In this file you'll find all the information to be able to build and change the source code, from setting up the environment, up to creating a package.

Working on your first Pull Request? You can learn how from this free series How to Contribute to an Open Source Project on GitHub), or you can contact us on our Discord server and we will be excited to help you in this journey!

Environment

  • Install Node.js: version 14.15 or higher
  • Install git

Setup

If you intend on contributing to the project, you will need to fork the main repository first, and then clone it to your local machine. If you just want to build it locally, you can clone directly from the main repository: https://github.com/thamara/time-to-leave

Clone the repository

To clone your the repository:

git clone https://github.com/<YOUR USER>/time-to-leave.git
cd time-to-leave

Install dependencies

npm ci
npm install

Running Time to Leave

To run Time to Leave, after the steps above:

npm start

Linting & formatting

Time to Leave uses several linting and formatting tools in order to guarantee that code is homogeneous and consistent.

Running and Fixing issues

Run the following before committing to guarantee the code you changed/added follows these rules:

npm run lint-fix

This will automatically fix the lint issues too. If you want to just check the potential issues, without modifying the code, use

npm run lint

Specific lint checks

Each type of file is related to a lint rule, and those can be run separately:

# css
npm run lint:css

# Node and Javascript
npm run lint:eslint
npm run lint:standard

# markdown
npm run lint:markdown

Tests

Time to Leave has tests that will verify the correctness of the flow using Jest. All tests are located in __tests__ directory. We have a workflow in the repository that will run all the tests when a Pull Request is submitted, and the change is only approved if the tests are passing.

Run locally

To run all tests locally:

npm run test:jest

After running, you'll see a message like:

Test Suites: 12 passed, 12 total
Tests:       83 passed, 83 total
Snapshots:   0 total
Time:        31.007 s
Ran all test suites in 2 projects.

If you got any errors (failed tests), you need to scroll up and check the module and the test that has failed. The error will look something like:

 FAIL   RENDERER  __tests__/__renderer__/themes.js
  Theme Functions
    isValidTheme()
      ✓ should validate (2 ms)
      ✓ should not validate (1 ms)
    applyTheme()
      ✕ should apply (3 ms)
      ✓ should not apply

The error message will tell you more on why it failed, in terms of what was expected and what was got.

Running specific tests

You can run a specific test, when debugging, for example, by including the name of the test file in the command line. For example, to run only the themes.js tests, you can do:

npm run test:jest themes.js

More information on jest settings available for use can be seen on jest's docs.

Note: Although possible to run just a few tests, it's highly suggested that you run all tests when changing the code.

Releasing

After building and testing, you may want to package the App, which is basically creating a single executable/installer that can be shared with others (without the necessity of installing other dependencies). This is not very common and you can skip this step during the development process (if you just want to contribute opening PRs). If a release is what you want, you can use the following commands:

# macOS
npm run package:mac

# Windows
npm run package:win

# Debian
npm run package:deb

These will create the respective file under release-builds/ directory.

Opening a Pull Request (PR)

All PRs are very welcome, and we'll do our best to review them as fast as possible. If you want to work on a specific issue, just shout out to us and we'll assign the issue to you. Once you are done, just submit a PR with a relevant description of the change, and provide screenshots, if applicable. Issues without activity for 7 days will be deemed stale and unassigned, unless justified. Tip: Before pushing the PR, make sure the tests are passing, and that no lint issue is present. :)

Feeling kind of lost?

Check out the architecture diagram on CodeSee.