Skip to content

Latest commit

 

History

History
194 lines (130 loc) · 6.44 KB

DEVELOPMENT.md

File metadata and controls

194 lines (130 loc) · 6.44 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 20.18 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/TTLApp/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 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 mocha and electron-mocha. Mocha tests are located in the tests directory, and electron-mocha are in the __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

It will expand to the two runner targets. The above is the same as doing:

npm run test:electron-mocha
npm run test:mocha

After running, you'll see a message like:

  4 passing (70ms)
  1 failing

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:

  Date Functions
    getDateStr(Date())
      1) Given a JS Date() object, should return YYYY-MM-DD
      ✔ Given an insane object, should return an error

...

  4 passing (70ms)
  1 failing

  1) Date Functions
       getDateStr(Date())
         Given a JS Date() object, should return YYYY-MM-DD:

      AssertionError [ERR_ASSERTION]: Expected "actual" to be strictly unequal to:

'2025-01-05'
      + expected - actual

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 one or more specific tests when debugging. That is done by including the path of the test file(s) in the command line along with a specific test runner target. For example, to run only the __tests__\__main__\date-aux.mjs file, you can use:

npm run test:electron-mocha .\__tests__\__main__\date-aux.mjs

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

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

Adding new dependencies

We are trying to keep exact versions in the package.json file so that every user that runs npm install gets similar results. npm install --save adds packages by default with a ^ notation, that indicates freedom to install versions above the specified. Thus, if you are adding a new dependency, you must use npm install --save --save-exact to add a specific version to the list of dependencies.

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.