Skip to content

Latest commit

 

History

History
139 lines (97 loc) · 4.51 KB

README.md

File metadata and controls

139 lines (97 loc) · 4.51 KB

JS_BackUp

(This is a backup of both frontend and backend of the YY-music site.)

We use this repo to build up the testing codes for both the frontend and backend.

In addition to the back up, we also have codes related to Unit Testing and Continuous Integration(Python pytest, Jest, PHPUnit, GitHub Actions, Generative AI)

Where to put the repo

Make sure that you've cloned the repository to the folder htdocs in XAMPP. Otherwise, the php test might not run.

Python test

Problem 1 (unit test without pytest)

Please run the code at PythonCode/problem1.py (Through terminal)

python -u "PythonCode/problem1.py"

Problem 2 (unit test with pytest)

How to set up the environment: (Through terminal)

pip install pytest

Run the test: (Through terminal)

pytest

Backend Test

Environment Config

Please setup the phpunit following the offcial document here.

How to run

Navigate to the backend folder of backend

cd backend
./vendor/bin/phpunit tests/StackTest.php

Hard coded id (song_id), username, password

For the testRegister, testLogin, and testFailLogin tests, the username and password are pre-defined in the test code. To ensure these tests run correctly, verify that the user defined by these credentials does not already exist in the database prior to running the tests.

'username' => 'test_admin',
'password' => '1234567890aaa',

In the testUpdateSong and testDeleteSong tests, we use the song_id as a parameter to identify the specific song we want to update or delete. This song_id is automatically generated and incremented in our SQL database whenever a new song is added.

Therefore, when writing or updating these tests, it's crucial to ensure that the song_id used in the test matches the song_id of the song you expect to be present in the database. This is because the song_id in the database will automatically increment each time a new song is added.

In other words, if you're writing a test to update or delete a song that you've just inserted into the database for testing purposes, you need to know the song_id that was assigned to that song and use it in your test. If the song_id in the test doesn't match any song_id in the database, the test will fail because it can't find the song it's supposed to update or delete.

public function testUpdateSong(): void
{
    ...
    'id' => '53',
    'username' => 'test_admin',
    'song_artist' => 'test_admin',
    'song_name' => 'admin_song',
    'song_rating' => '4',
    ...
}
public function testDeleteSong(): void
{
    ...
    'id' => '53',
    'username' => 'test_admin',
    ...
}

Frontend Test

Environment Config

before running the test, please make sure you have node and npm installed.

How to run

In your command line, enter the following command to build the environment and then run the test:

cd .. # if you're still in the backend directory
npm ci
npm test # if the test doesn't run please press `a` to manually run all the tests

The tests

  • The rendering test is in render.test.js
  • The Link test is in link.test.js
  • The input test is in searchInput.test.js & incorrectValue.test.js
  • The incorrect value test is in incorrectValue.test.js
  • The search functionality test is in searchInput.test.js (new functionality)

Generative AI

We used ChatGPT to generate some part of the test. In particular, the fetchMock function in Songdisplay.test.js test is generated by ChatGPT. At the time we tried to write the test that examine the search function, we need to mock the case that the frontend fetches the data from the backend. However, we don't know how to mock the fetch function. Therefore, we asked gave our initial code to ChatGPT and asked "can you help me imporve this test by mocking the backend response and fetch some song info?". Then ChatGPT generated the code

// The fetchMock part is generated by GPT4
fetchMock.enableMocks();

beforeEach(() => {
  fetch.resetMocks();
  fetch.mockResponse(
    JSON.stringify([
      // Mock data: Array of song objects
      { id: 1, username: "user1", artist: "artist1", song: "song1", rating: 3 },
      { id: 2, username: "user2", artist: "artist2", song: "song2", rating: 5 },
    ])
  );
});

We then used this code to test our search function.

Member Contribution

This repo includes Unit Testing and Continuous Integration(Python pytest, Jest, PHPUnit, GitHub Actions, Generative AI) for COMP 333: Software Engineering 2023 Harry Yu 50% Patton Yin 50%