All integration tests completed #25
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Server Test | |
on: | |
push: | |
branches: [main] | |
pull_request: | |
branches: [main] | |
jobs: | |
test: | |
runs-on: ubuntu-latest | |
steps: | |
- uses: actions/checkout@v4 | |
- name: Use Node.js | |
uses: actions/setup-node@v4 | |
with: | |
# Adjust version according to your requirements | |
node-version: "20.x" | |
cache: "npm" | |
cache-dependency-path: server/package-lock.json | |
- name: Cache node modules | |
id: cache-nodemodules | |
uses: actions/cache@v3 | |
env: | |
cache-name: cache-node-modules | |
with: | |
# Update path to cache the node_modules directory inside the /server sub-folder | |
path: server/node_modules | |
# Update path to hash package-lock.json inside the /server sub-folder | |
key: ${{ runner.os }}-build-${{ env.cache-name }}-${{ hashFiles('**/package-lock.json') }} | |
restore-keys: | | |
${{ runner.os }}-build-${{ env.cache-name }}- | |
${{ runner.os }}-build- | |
${{ runner.os }}- | |
- name: Install Dependencies | |
if: steps.cache-nodemodules.outputs.cache-hit != 'true' | |
run: | | |
cd server | |
npm ci | |
- name: Run tests | |
run: | | |
cd server | |
touch .env | |
# Database variables | |
echo "DB_URL=${{ secrets.DB_URL }}" >> .env | |
echo "DB_SERVICE_ROLE_KEY=${{ secrets.DB_SERVICE_ROLE_KEY }}" >> .env | |
echo "DB_DIRECT_URL=${{ secrets.DB_DIRECT_URL }}" >> .env | |
# Jwt key | |
echo "JWT_SECRET_KEY=${{ secrets.JWT_SECRET_KEY }}" >> .env | |
# Testing variables | |
echo "QA_NAME=${{ secrets.QA_NAME }}" >> .env | |
echo "QA_EMAIL=${{ secrets.QA_EMAIL }}" >> .env | |
echo "QA_USERNAME=${{ secrets.QA_USERNAME }}" >> .env | |
echo "QA_PASSWORD=${{ secrets.QA_PASSWORD }}" >> .env | |
echo "QA_NAME_EXISTS=${{ secrets.QA_NAME_EXISTS }}" >> .env | |
echo "QA_EMAIL_EXISTS=${{ secrets.QA_EMAIL_EXISTS }}" >> .env | |
echo "QA_USERNAME_EXISTS=${{ secrets.QA_USERNAME_EXISTS }}" >> .env | |
echo "QA_PASSWORD_EXISTS=${{ secrets.QA_PASSWORD_EXISTS }}" >> .env | |
echo "QA_NAME_GUEST=${{ secrets.QA_NAME_GUEST }}" >> .env | |
echo "QA_EMAIL_GUEST=${{ secrets.QA_EMAIL_GUEST }}" >> .env | |
echo "QA_USERNAME_GUEST=${{ secrets.QA_USERNAME_GUEST }}" >> .env | |
echo "QA_PASSWORD_GUEST=${{ secrets.QA_PASSWORD_GUEST }}" >> .env | |
# AWS variables | |
echo "AWS_ACCESS_KEY_ID=${{ secrets.AWS_ACCESS_KEY_ID }}" >> .env | |
echo "AWS_SECRET_ACCESS_KEY=${{ secrets.AWS_SECRET_ACCESS_KEY }}" >> .env | |
# S3 bucket variables | |
echo "S3_BUCKET_LINK=${{ secrets.S3_BUCKET_LINK }}" >> .env | |
echo "S3_IMAGE_LINK=${{ secrets.S3_IMAGE_LINK }}" >> .env | |
echo "S3_CLOUDFRONT_LINK=${{ secrets.S3_CLOUDFRONT_LINK }}" >> .env | |
# Moderator variables | |
echo "MOD_URL=${{ secrets.MOD_URL }}" >> .env | |
echo "MOD_KEY=${{ secrets.MOD_KEY }}" >> .env | |
echo "MOD_HOST=${{ secrets.MOD_HOST }}" >> .env | |
# Run tests | |
npm test | |
- name: Remove .env | |
run: | | |
cd server | |
rm .env |