Below instructions cover dockerization & deployment process of our application for users who wants to test/use the application on their local environments.
Please note that this guide covers this process in the context of Customer Milestone 3.
- Docker
- Docker-Compose
- It is sufficient to have the Docker Desktop application for having both of these application above. You can access the necessary document here.
Please follow this guide step by step in order to create a local build and run the application on the same environment.
- It is highly recommended to clone our repository on to the environment where the application is going to be built. Then, simple change your directory into the root folder of our repository.
git clone https://github.com/bounswe/bounswe2024group11.git
cd ./bounswe2024group11
- To have the latest changes included, it is recommended to switch to the
main
branch.
git fetch
git checkout main
git pull
- Our application needs an
.env
files to configure some settings inside its containers during the build process. Since.env
files are ignored by.gitignore
, it is required to have these files for local deployment. - Make sure that current directory is the root directory of repository.
cp ./backend/.env.example ./backend/.env
cp ./client/.env.example ./client/.env
- If you want to use/test image uploading feature, please fill in the
TINIFY_API_KEY
environment variable's value in the./backend/.env
file with your API key from TinyPNG. - If you don't have a
TINIFY_API_KEY
, you can use our sample API key.
TINIFY_API_KEY=KJNsyVSbRs0xRCpbbhBjr5PfPDbWS5K6
-
After completing steps above, the host machine should be ready for docker builds. It is important to note that users need to install docker-compose program on top of docker itself. It is also recommended to add docker-compose command to the $PATH if it is not configured so.
-
It is highly recommended to have the Docker Desktop application installed for ignoring the step above.
-
It is important to use the
docker-compose.yml
file for building the application.-d
flag runs docker-compose in detached mode to not block the shell during the run. -
Below command is sufficient to build & run the application. Make sure that your Docker Desktop application is running, since below command will require to docker daemon to be up & running.
docker-compose -f docker-compose.yml up --build -d
- Follow the instructions here to set your environment ready to develop using React Native.
- Install Expo CLI globally
npm install -g expo-cli
- Install Expo Go on your Android device from the Google Play Store if it's not installed automatically.
- Navigate to the mobile folder.
cd ./mobile
- Install dependencies for the mobile application:
npm install
- Start the Expo development server:
npx expo start
- Press a.
- Ensure your Android emulator is connected to the same Wi-Fi network as your development machine.
- You can use Docker Desktop application for viewing running containers and their conditions.
- You can simply browse "http://localhost" for viewing the homepage of our client application for further use.
- Again, Docker Desktop application is sufficient to stop or remove the built containers, images, builds and volumes.
- Or you can use the shell for this purpose.
docker ps # see running containers with their info
docker-compose down # stop and remove running containers
docker image prune -a # remove all images built
In LAB-5, the team made significant efforts to document and adhere to the project's standards, namely WAI-ARIA, WCAG, and SVG.
Responsible individuals: Arda Vural, Hasan Kerem Seker, M. Emin Ciftci, Umit Can Evleksiz.
Primary features (e.g. semantic search, user management), Domain-specific features (e.g. why they're specific, how they're implemented), API and its documentation (e.g. endpoints, expected inputs, outputs), Standard(s) being followed (e.g. its documentation, implementation), Testing strategies (e.g. unit test coverage, integration testing, tools).