Thank you for your interest in contributing to the FreeAPI project to help us deliver our APIs that are battlefield tested. To ensure reliability & stability for our end users, we utilize Playwright, a powerful testing framework to automate testing across all endpoints.
After exploring our open-source community options such as Jest, Jasmine & Playwright. We decided to move forward with the playwright as it facilitates automated testing, offers cross-browser support, rich enough API with familiar syntax.
- create an issue stating which module you will be working on
- in a given module if tests exist, we do not welcome them as long as it is a logical fix
- test coverage for example frontend apps are not our top priority
IMPORTANT: Contributor must create an issue with Testing Contribution issue template.
This ensures coordination and prevents duplicated efforts.
- 🏁 Getting Started
- 👆🏻 Choosing a Module
- 🗂️ Folder Structure
- 📙 Coding Standards
- 📝 Dependency Management
- 📨 Submitting Your Contribution
Start by forking the FreeAPI project repository to your GitHub account.
Clone your fork of the repository to your local machine.
git clone https://github.com/<your_username>/apihub.git
cd apihub
Make sure you have the necessary dependencies of FreeAPI installed for the frontend framework or library you plan to use.
Follow this README.md section to know more about setting up the FreeAPI environment
Decide which module you want to contribute to. Browse the /apps
, /public
, or /kitchen-sink
modules to explore the available modules and APIs. Read the following section carefully to understand the folder structure you need to follow to increase your chances of getting your PR approved.
Follow the specified folder structure for your frontend application (The folder names must not follow the camel casing to keep things consistent. Your actual project code folders may have camel casing):
ROOT_FOLDER/e2e/{module}/
See the following examples with context for the above structure:
Imagine you want to test the todo endpoint that is part of /apps
module of the FreeAPI project. To keep a consistent folder structure for backtracking name your files with name identifier, but with an extension of .test.js
.
$ROOT_FOLDER/e2e/{package}/{module}/{file-indicator}.test.js
-
ROOT_FOLDER
: Refers to the root directory of the FreeAPI project. -
e2e
: This directory is designated for including test cases. -
{package}
: The directory contains typical of a Node.js application:app.js
initializes the app,controllers
handle requests,models
define data structures,routes
map endpoints,utils
provide utilities, and others manage logging, authentication, and database interactions. -
{module}
:apps
orpublic
orkitchen-sink
: Denotes the chosen module (/apps
for complex apps,/public
for public APIs,/kitchen-sink
for backend-related static APIs. These folders are already created officially). -
{file-indicator}
: This is the actual file name indicator that helps to identify for which file you are writing test cases for example:todo.test.js
By following this standardized folder structure, contributors can easily organize their front-end projects, making it convenient for others to explore, understand, and replicate the implementation.
Adhere to the coding standards of the playwright framework. Additionally, consider the following guidelines:
- Use clear descriptive test suite & block names
- Follow best practices for unit, integration & end-to-end testing
- Ensure your code is well-documented by comments wherever necessary
- Make sure to add both positive & negative test cases
Ideally, we do not encourage you to include a new package. Confine your code practices within the available dependencies to avoid overheads. Please state with a clear explanation with examples if you add anything new.
Click here for a detailed contribution guide on submitting a PR.
Thank you for your contribution to FreeAPI! Your dedication helps make our APIs more accessible and valuable to the community. If you have any questions or need assistance, feel free to reach out to our Discord.
Thank you for being part of the FreeAPI community and contributing to the project! We look forward to featuring your fantastic work. 🌟
Happy coding! 🚀