Quizki is a question and answer database which generates exams. This is the backend of the project. For the frontend go to team-quizki/quizki-frontend.
This project uses Spring Boot v2.0.3.
Here is what you need to do to get the project up and running on your local machine for development and testing purposes.
To run the backend you will need the following tools
- Oracle Java Use JDK8 as JDK11 currently does not work with quizki-backend.
- Apache Maven Check if you have it by typing
mvn -v
- Oracle MySQL
Other tools you will need if you are new to quizki-backend or to backend coding:
Install the dependencies (above) per the instructions for the given software package.
Install the dependencies (above) per the instructions for the given software package.
These dependencies can be installed using the Homebrew package manager for macOS.
- Maven
$ brew install maven
- MySQL
$ brew install mysql
You will need to fork the team-quizki/quizki-backend repository, then clone your new fork to your local computer, and configure the cloned copy on your computer. You can follow these instruction on Github. To summarize this instruction:
-
On GitHub fork the team-quizki/quizki-backend repository.
-
Using Git Bash or Git CMD clone your newly forked repository to your local computer:
$ git clone https://github.com/<<UseYourGitHubHandleHere>>/quizki-backend.git
-
Change to the quizki-backend directory.
$ cd quizki-backend
-
Configure your local quizki-backend to use remote upstream.
$ git remote add upstream https://github.com/team-quizki/quizki-backend
-
Check remote origin and upstream looks similar to the following.
$ git remote -v
origin https://github.com/FrauDeborah/quizki-backend.git (fetch)
origin https://github.com/FrauDeborah/quizki-backend.git (push)
upstream https://github.com/team-quizki/quizki-backend.git (fetch)
upstream https://github.com/team-quizki/quizki-backend.git (push)
-
Configure your user email to prepare for commit
$ git config --global user.email "[email protected]"
-
Configure your name email to prepare for commit
$ git config --global user.name "Your Name"
You will only need to do this the first time you run the backend.
- Initialize a user. You may or may not need
sudo
.$ [sudo] mysql -u root -p < ./src/main/resources/META-INF/sql/init_quizki2_user.sql
- Populate the database. The password for the
quizki2
user in mysql isquizki2.
$ mysql -u quizki2 -p < ./src/main/resources/META-INF/sql/populate_quizki2_db_20190201.sql
You can check that it is working by entering the database. $ mysql -u quizki2 -p quizki2_db --execute="show tables;"
You should see a list of 'Tables in quizki2 db'.
To get the backend running on your local machine, you will need a MySQL daemon running and you will need to compile and run the application. Follow these steps each time you want to run the backend.
- Run a MySQL daemon in the background.
$ mysqld
- Compile and run the application by using the Spring Boot Maven plugin.
$ mvn spring-boot:run
Type $ mvn test
.
The project is not yet ready for deployment. We will add additional notes about how to deploy this on a live system when it is ready.
- Oracle Java We've done light testing up through JDK9.
- Apache Maven Check if you have it with
$ mvn -v
- Oracle MySQL
This is a project of the Denver Mock Programming Job group. Find us at our Meetup page.
Please read [CONTRIBUTING.md] for details on our code of conduct, and the process for submitting pull requests to us.
This project is in alpha version.
- Johnathan
- Jim
- Deborah
- Jeremiah
- Nabil
GPL v3.0 all day.