Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/jaktestowac/gad-gui-api-demo

GAD๐ŸฆŽ - Application for learning testing GUI and API
https://github.com/jaktestowac/gad-gui-api-demo

api gui testing

Last synced: about 2 months ago
JSON representation

GAD๐ŸฆŽ - Application for learning testing GUI and API

Awesome Lists containing this project

README

        

# Introduction


GAD

This application (called **๐ŸฆŽ GAD**) was prepared and developed **only for testing purposes**. It provides:

- GUI
- REST API
- Swagger Doc

This application contains simple logic, statistics, charts, games, different resources, **deliberately prepared bugs**๐Ÿ› and various challenges.

Thanks to this configuration, we are able to **reflect real project reality**๐Ÿ˜‰

P.S. In addition, the application has some **serious design flaws** - I wonder if you will notice them?๐Ÿ˜‰

# Features

Features of **๐ŸฆŽ GAD**:

- **GUI** (front-end)
- **REST API** (back-end)
- **Swagger** Doc
- Simple **DataBase** (JSON) with REST API endpoints to clear/restore all data
- **Authentication** and **Authorization**
- **User** <-> resources logic (calculations, statistics)
- Different **data presentation** (charts, tables etc.)
- **Feature flags** configurable from UI!
- **Bug flags** to enable/disable different bugs - configurable from UI!
- **Dynamic config**
- **Challenging elements for test automation** (iframes, file uploads, drag&drop, likes, labels, surveys, banners, pop-ups, logic on front-end and back-end, dynamic elements, games etc.)
- **Admins "backoffice"** with additional tools and functionalities (DB reset, SQL Playground)

# Deployment

Instructions how to deploy presented service to various free hosting sites.

- [Deploy to Local](#deploy-to-local) (recommended)
- [Deploy to Glitch](#deploy-to-glitch)
- [Deploy to Render](#deploy-to-render)
- [Deploy using Docker image](#deploy-using-docker-image)

## Deploy on **Local**

Requirements:

- **node.js** installed in the system
- tested on node.js **v18** and **v20**
- **git** installed in the system

### First use

Steps:

1. Open the project root directory in cmd/terminal
1. Clone the repository using `git clone ...`
- this is the **preferred way** to use this application
1. Run `npm i`
- to install modules (don't use node.js global packages!)
1. Run `npm run start`
- to start GAD

The application will be available at `http://localhost:3000`

### Update version

#### If You are using zip package

Steps:

1. Download zipped repository
1. Unzip and replace Your local instance of GAD
1. Run `npm i` in root directory
- to install new modules
1. Run `npm run start`
- to start GAD

#### If You are using cloned repository

Steps:

1. Open the project root directory in cmd/terminal
1. Pull latest changes using `git pull`
1. Run `npm i`
- to install new modules
1. Run `npm run start`
- to start GAD

### Update version if You have any changes (e.g. in database)

One possibility is to reset all Your local changes and pull new version.Using this method **You will lose all Your local changes and data**!

Steps:

1. Open the project root directory in cmd/terminal
1. Reset local changes and pull latest changes using:
```
git reset --hard HEAD
git pull
```
1. Run `npm i`
- to install new modules
1. Run `npm run start`
- to start GAD

### CLI options

| Option | Description |
| ------------ | ------------------------------------------------------------------------------------------------------------------------------------ |
| READ_ONLY=1 | Run in Read Only mode. This disables all POST, PUT, and PATCH methods, besides login. |
| PORT=3001 | Run on selected port. GAD runs on default port `3000`. |
| DB="db_name" | Use selected database file. GAD uses `db.json` as default database. Example (for PowerShell): `$env:DB="db-base-big"; npm run start` |

โš ๏ธ Warning: Any environment variables set in the terminal will be used by the application. If you want to run the application without any options, make sure to clear the environment variables.

#### Running CLI options

To run GAD with **CLI options**, use the following commands e.g.:

PowerShell:

```PowerShell
$env:PORT=3001; npm run start
```

Bash:

```Bash
PORT=3001 npm run start
```

Windows Cmd:

```
set PORT=3001 && npm run start
```

## Deploy to **Glitch**

No account needed - but your project will be deleted in 5 days.

After clicking button below wait a minute or two to finish deployment.

[![Remix on Glitch](https://cdn.glitch.me/2703baf2-b643-4da7-ab91-7ee2a2d00b5b%2Fremix-button-v2.svg)](https://glitch.com/edit/#!/import/github/jaktestowac/gad-gui-api-demo)

To see website:

- go to bottom buttons
- click `๐Ÿ”ŽPREVIEW`
- choose `๐Ÿ‘ฏPreview in a new window`

When deploying the GAD application on Glitch, please be aware that the application may not function fully due to the limitations of the Glitch platform. However, we are making every effort to ensure the highest possible compatibility.

## Deploy to **Render**

- Create free account on: https://dashboard.render.com/register
- After successful registration hit the button:

[![Deploy to Render](https://render.com/images/deploy-to-render-button.svg)](https://render.com/deploy?repo=https://github.com/jaktestowac/gad-gui-api-demo)

- name your app
- hit `Apply`
- wait a while and click link to project `GUI API Demo`
- click link to open app (under project name and repository)
- enjoy 750 free hours of service per month

When deploying the GAD application on Render, please be aware that the application may not function fully due to the limitations of the Render platform. However, we are making every effort to ensure the highest possible compatibility.

## Deploy using Docker image

This method can be used:

- locally
- in CI/CD services (GitHub Actions, GitLab CI etc.)

### Prerequisites:

On local environment:

- latest Docker is installed

### Running

Just run following command to get latest image:

```
docker run -p 3000:3000 -d jaktestowac/gad
```

or specific version:

```
docker run -p 3000:3000 -d jaktestowac/gad:2.5.5
```

Application should be running under http://localhost:3000/

Images are available at:
[๐Ÿ‹ hub.docker.com/repository/docker/jaktestowac](https://hub.docker.com/repository/docker/jaktestowac/gad/general)