This page provides a guide for anyone to test new DSpace 7 features/bug fixes in open GitHub Pull Requests. No prior experience or technical knowledge (beyond basic command-line) is necessary. All steps are provided below. |
One of the larger challenges to fixing a bug or improving/adding a new feature is end user testing. This activity is often reliant on other developers, but can be helped along by those in non-technical roles. As a general policy, DSpace Committers require at least two reviewers/testers (from different institutions) for every Pull Request. While this policy helps ensure all new code is stable, it can result in an accidental "bottle-neck" or roadblock if a secondary reviewer/tester cannot be located quickly.
While we do require automated tests for every new Pull Request, automated tests are not always able to accurately replicate normal user behavior.
Therefore, when more people are able to get involved in testing new code, the result is more stable & bug-free code. Additionally, it increases the speed at which new code can be accepted – allowing us to get more features/fixes in each release of the software.
If you are less technical, or just getting started, we recommend beginning your testing (or code review) with Pull Requests that contain the "1 Approval" label. These are smaller Pull Requests that need a very quick test or review (usually a small bug fix or improvement).
You are welcome to test any open pull request. Even if the pull request is already assigned to other testers, it can help speed up its completion/acceptance if others also test it.
We recommend testing whichever pull requests are of interest to you. You may find one relating to a bug that you'd also seen, or something that sounds easy for you to test, etc. The choice is up to you.
In order to get started with testing DSpace Pull Requests (PRs), you need the following setup on your machine.
NOTE for Windows 10: Docker Desktop can sometimes become a bit "memory hungry" when it is running. It's best to either disable the "Start Docker Desktop when you log in" setting (so that you only run it when needed). Or, if you are using the default WSL2 backend, you can create a ".wslconfig" file in your user directory and limit the amount of memory you let Docker use (at least 4-8GB is recommended if you can spare it):
[wsl2] memory=8GB |
If this is your first time using GitHub CLI (gh), you likely will need to authenticate with it using your GitHub.com login.
|
First, clone the backend codebase using GitHub CLI (gh). This downloads all the code from https://github.com/DSpace/DSpace into a local directory named "DSpace".
# Run from command-line where ever you want the "DSpace" directory of code to be created. gh repo clone DSpace/DSpace # Once downloaded, change into that directory cd DSpace |
Using Docker, pull down the latest backend images from DockerHub. This downloads all the prebuilt Docker images so you don't need to rebuild them locally.
# This command should be run from the "DSpace" code directory docker-compose -f docker-compose.yml -f docker-compose-cli.yml pull |
Using Docker, start the Backend on Docker & automatically install our Entities Test Data
# First start the backend with the test data docker-compose -p d7 -f docker-compose.yml -f dspace/src/main/docker-compose/db.entities.yml up -d # Run "logs -f" to watch the logs for everything to start up. Or, just wait a few minutes until http://localhost:8080/server/ responds. docker-compose -p d7 -f docker-compose.yml -f dspace/src/main/docker-compose/db.entities.yml logs -f # (Click Ctrl+C to exit logs view) # Finally, download the test data assestore (of files) and install it, reindexing all content docker-compose -p d7 -f docker-compose-cli.yml -f dspace/src/main/docker-compose/cli.assetstore.yml run dspace-cli |
First, clone the frontend codebase using GitHub CLI (gh). This downloads all the code from https://github.com/DSpace/dspace-angular to a local directory named "dspace-angular". You may wish to run this command from the same parent directory where you cloned the backend (just to keep this new "dspace-angular" folder next to the "DSpace" folder where the backend code resides).
# Run from command-line where ever you want the "dspace-angular" directory of code to be created. gh repo clone DSpace/dspace-angular # Once downloaded, change into that directory cd dspace-angular |
Using Docker, pull down the latest frontend images from DockerHub. This downloads all the prebuilt Docker images so you don't need to rebuild them locally.
# This command should be run from the "dspace-angular" code directory docker-compose -f docker/docker-compose.yml pull |
Using Docker, start the frontend/UI:
docker-compose -p d7 -f docker/docker-compose.yml up -d # Optionally run "logs -f" to watch the logs for everything to start up. docker-compose -p d7 -f docker/docker-compose.yml logs -f # (Click Ctrl+C to exit logs view) |
You are now ready to test PRs! See below for how to do so. |
Based on the setup above, here's how to test a new User Interface / Frontend Pull Request in the "dspace-angular" project: https://github.com/DSpace/dspace-angular/pulls
These test instructions assume you are already running both the Frontend & Backend. If not, follow the instructions above, and then start them both:
# Start backend cd DSpace docker-compose -p d7 up -d # Start frontend cd ../dspace-angular docker-compose -p d7 -f docker/docker-compose.yml up -d |
Move into the directory where your Frontend code is:
cd dspace-angular |
Find the number of the Pull Request you want to test (it'll be the "#[number]" displayed after the PR name, or the end of the PR's URL). Checkout the code from that PR using it's number:
# This would checkout https://github.com/DSpace/dspace-angular/pull/1383 for testing gh pr checkout 1383 |
Now, rebuild & restart your frontend based on that PR's code:
docker-compose -p d7 -f docker/docker-compose.yml up -d --build # Even after the build completes, it may take a few minutes for the frontend to restart # You can check the status using "logs -f" docker-compose -p d7 -f docker/docker-compose.yml logs -f # (Click Ctrl+C to exit logs view) |
Some frontend bugs or features also require backend changes. Here's how to install those backend PR changes. Yes, you can even test a backend PR and frontend PR at the same time by following the instructions in both "Testing a Frontend PR" and "Testing a Backend PR".
These test instructions assume you are already running both the Frontend & Backend. If not, follow the instructions above, and then start them both:
# Start backend cd DSpace docker-compose -p d7 up -d # Start frontend cd ../dspace-angular docker-compose -p d7 -f docker/docker-compose.yml up -d |
First, move into the directory where your Backend code is
cd DSpace |
Find the number of the Pull Request you want to test (it'll be the "#[number]" displayed after the PR name, or the end of the PR's URL). Checkout the code from that PR using it's number:
# This would checkout https://github.com/DSpace/DSpace/pull/8007 for testing gh pr checkout 8007 |
Now, rebuild & restart your backend based on that PR's code:
docker-compose -p d7 up -d --build # Even after the build completes, it may take a few minutes for the backend to restart # You can check the status using "logs -f" docker-compose -p d7 logs -f # (Click Ctrl+C to exit logs view) |
After restarting your computer, the frontend & backend will be stopped. If you previously installed both & simply need to start them up again, run the following:
# Start backend cd DSpace docker-compose -p d7 up -d # Start frontend cd ../dspace-angular docker-compose -p d7 -f docker/docker-compose.yml up -d |
NOTE: While this shuts down the Docker containers, all the data/files/user accounts you created will be retained (and will appear the next time to start the containers)
# Stop the backend cd DSpace docker-compose -p d7 down # Stop the frontend cd ../dspace-angular docker-compose -p d7 -f docker/docker-compose.yml down |
# Checkout the main code (from either frontend or backend directory) git checkout main # Pull down any latest changes git pull # Rebuild/restart the frontend or backend # For frontend: docker-compose -p d7 -f docker/docker-compose.yml up -d --build # For backend: docker-compose -p d7 up -d --build |
NOTE: This removes all Docker containers from your system, including all data created in those containers. After running this, you delete everything. So, if you want to do future testing, you'd have to reinstall both the frontend & backend (using the instructions above) from scratch.
# First, shutdown everything that's running in Docker docker stop $(docker ps -a -q) # Now, delete all Docker containers from your machine docker rm $(docker ps -a -q) # Remove all Docker volumes (data) from your machine docker volume rm $(docker volume ls -q) # Finally, you may delete the "DSpace" and "dspace-angular" folders if you no longer wish to use them. # You may also uninstall Docker Desktop and GitHub CLI if you wish. |