Skip to content

Latest commit

 

History

History
171 lines (105 loc) · 8.82 KB

CONTRIBUTING.md

File metadata and controls

171 lines (105 loc) · 8.82 KB

Github Marketing

You can help out the project by just ★ starring this repository from the upper right corner and also pinning it to your profile.

Getting Started

It's very easy to set-up a local server in order to test and contribute to the development version of this game project.
It uses web languages like HTML, CSS, Javascript and Node.js. The game engine used is free open source, Phaser. Nowadays you can skip setting up a local server and just start developing on the project right away: Open in Gitpod

Recommended Tool

If you're not very keen on using a browser based IDE, I highly recommend using Visual Studio Code, for cloning the project and creating patches. VSC is free, open source, cross platform, and has nice git integration and useful extensions.

Fork Project

You can create a clone of the project by using git from the CLI or with the use of a tool like the one recommended above.

git clone https://github.com/FreezingMoon/AncientBeast.git

In VSC you can press Ctrl + Shift + P, search for Git: Clone and then input just the link in the given field.


Package Requirements

First install (or make sure you have) the latest LTS version of Node.js. In case you need to have different versions of it for other projects as well, you should definitely use nvm (Node version manager), which is a tool that makes it easy to manage multiple local Node installations. You can find installation instructions here, and then use it like:

nvm install --lts  # This will always install the latest LTS release.
nvm use --lts  # Use latest LTS now.
nvm alias default  # Make latest LTS your default.

LTS stands for Long Term Support, meaning it's a rather stable and hopefully non-problematic version.

Installing Dependencies

In the terminal (Ctrl + ~ in VCS), use the following command in order to easily install all the project dependencies:

npm install

This will read package.json and install all of the gameplay established npm package dependencies.
The npm install command will also update any required dependencies if the package.json file changes. If you have not worked on the project in a while, make sure you update your fork and also run that command again, which will also compile the project, same as the npm run build:dev command.

Setup environment variables

If you want to customize your local setup, duplicate existing .env.example file as .env, adjust it as you want and that file will become default.

cp .env.example .env

Compile Project

In order to build the development version of the game (also done by npm install), run the following command:

npm run build:dev

If you receive errors about the manifest or assets loading, try running npm run assetLister to create a list for the app.

Docker Setup

As an alternative way of running the project, make sure you have Docker installed, then build the image using the following command:

docker build -t yourusername/ancient-beast .

To run the image, use this command:

docker run -p80 yourusername/ancient-beast

If there's something already running on port 80 or it's being blocked, try the next port.

Beta Testing

To have the game up and running on your local machine, simply run this command in the terminal:

npm run start

Then access it using Chromium or Google Chrome, as support for other browsers is not guaranteed:

localhost:8080

You can usually test our latest (and greatest) master branch without any hassle from our auto-deployed beta app.

A handy tip while testing: you can right click the game tab and mute it by simply clicking the Mute site option.


Getting Involved

After you've play-tested the development version of the game, there are 2 main ways you can contribute to the project. For a more comprehensive guide on how to help out the project, you can check out the Make Your Contribution guide.

Report Issues

If you encounter any problems with this version, you can report them to our GitHub Issue tracker. Very often, it will be very helpful for debugging purposes to fetch game logs when encountering issues. You can use the AB.getLog() function from the browser console window in order to fetch the current match log. In order to open up Google Chrome browser's console, you can press Ctrl + Shift + J. To replay a match, you'll have to be in the pre-match screen, paste its log in the console and then press the Return key.

The Meta Powers screen can also be useful for achieving the correct game state to test features and reproduce bugs.

To access the Meta Powers screen:

  • Run the local development server.
  • Start a hotseat (single player) game.
  • When the game starts, press the Meta + Alt + P key combination.
  • Hovering each power shows a tooltip description.

Patch Game

The main coding language used is Javascript, feel free to create patches and propose them by making a Pull Request. You should look around on the GitHub Issue tracker for open issues, priority being the ones that are assigned to the next milestone and are tagged "Priority", while also lacking the "Brainstorm" tag. You can ping DreadKnight in the Discord server in order to be assigned to something specific, otherwise you can comment on a specific issue in order to receive the green light for it, making sure there's nobody else currently working on the issue or that design hasn't changed and a patch is still required. The game engine we're using is the community edition of Phaser, which is free and open source, and has nice documentation.

In order to patch the game and constantly test it, run it using this command, which will keep track of any file changes:

npm run start:dev

Then access it using Chromium or Google Chrome, as support for other browsers is not guaranteed:

localhost:8080

Keep in mind that you'll have to refresh the webpage after making changes. Make sure to disable browser caching by using Ctrl + Shift + J, then going to the Network tab and checking Disable cache.

Unit Tests

Each unit ability should have an unit test using our framework of choice, Jest, which can be written following the examples from official documentation. Our project's installed linter and the checks run on GitHub require that the Jest module values be imported explicitly:

import { expect, describe, test } from '@jest/globals';

See /src/__tests__/utility/string.js for an example.

Running Tests

The test runner was added to the existing npm run test.

In addition, the following commands were added to package.json:

  • npm run jest – Run tests
  • npm run start:jest – Watch test files and rerun when modified

Next Step

You are free to browse existing issues (for beginner coders there are issues labeled as easy) and comment on the ones that you want to take a swing at in order to make sure the issue is still relevant and that nobody else is working on it. You can also drop by the project's Discord server and mention your skills and that you're interested in helping out; you'll be assigned to a specific issue. When you're done, simply create a Pull Request. Note that you might need to pull in from master repository before doing so. Your patches will get reviewed and tested, if there are issues with them, you'll receive feedback in order to make corrections. Otherwise, your pull request will get approved and merged into the master branch and you'll get credited for it.


More Ways

Coding is not the only thing required in order to make this project as awesome as possible, see How to Contribute guide.