Skip to content

horsepowerjs/framework

Repository files navigation

Contributing

To contribute code to the horsepower framework take the following steps:

  1. Clone the repository
  2. Install the dependencies
  3. Run the linkage tool
  4. Build the packages
  5. Testing
    • PM2
    • Manual

Setting up the environment

The following steps will get you on the right path to make changes and contribute to the framework. There are a few optional steps that will be marked as so.

Clone the repository

Clone the repository to a folder of your choosing. If you plan on contributing to multiple horsepower repositories, it is recommended to place them in a horsepower or such directory.

# Optional commands
mkdir horsepower
cd horsepower

# Required commands
git clone [email protected]:horsepowerjs/horsepower.git

Install the dependencies

Some npm dependencies are needed for building the framework, so here is where we will install them.

cd framework
npm install

Run the linkage tool

Not all dependencies rely on one another, but during development we will just link everything together by running the linker.

./link.sh

Build the packages

The packages can be built one of two ways:

  • A single build
  • A watching build

A single build will build all of the packages once and then exit, whereas a watching build will build all of the packages and watch for changes then rebuild individual packages only when they have changed.

# Runs a single build
gulp build

# Runs a build and watches for changes to individual packages
gulp build:watch

Testing

The simplest way to test is to install the @horsepower/cli tool, this will download and install the horsepower packages from Github

# Install the cli
npm i -g @horsepower/cli

# CD into the parent directory of a test project
cd ~/Documents/www

# Run the new command from horsepower
# where "<website-name>" is the name of the new directory
horsepower new <website-name>
cd <website-name>

# Create links to the framework
# We don't want to use the production versions here
# These should have already been created when `./link.sh` was executed
npm link @horsepower/router
npm link @horsepower/session
npm link @horsepower/storage
npm link @horsepower/middleware
npm link @horsepower/server
npm link @horsepower/template
npm link @horsepower/mysql

You may want to edit the .env file and if so do that now because it needs to be done before the server is started. Any changes to that file will require the server to be manually restarted.

Once ready, you can run the server however you would like.

PM2

PM2 is a process manager that allows you to manage one or more processes. This will help us by allowing us to automatically restart the server in the background when the project files change. This way we don't need to manually do it ourselves every time we save/create/delete etc.

The horsepower install comes with a PM2 configuration file that is setup to watch directories.

We may want to add an additional watch path in the PM2 configuration file for development purposes to also watch for changes to the framework within the node_modules directory:

module.exports = {
  apps: [
    {
      watch: [
        // Previously listed paths
        path.join(__dirname, 'node_modules/@horsepower/*/lib/**/*.js')
      ]
    }
  ]
}

We can now install (if needed) and/or start the server via PM2.

# Optional: If you don't have pm2 installed
npm i -g pm2

# Start the pm2 server
pm2 start ./ecosystem.config.js
# Open the log file to view the errors and output
pm2 log

Manual

Manual testing is fairly straight forward. You will just need to execute the file in the classic nodejs manner. Whenever you change a file you will need to manually restart the node server unlike a process manager.

cd <website-name>
node ./index.js

About

Framework for the horsepower http server

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages