Building and Running
Running the stack
With Docker installed,
- 
Run the following: $ make init-db-testto create the knora-test repository and initialize it with loading some test data into the triplestore (Fuseki). 
- 
Start the entire knora-stack (fuseki (db), sipi, redis, api, salsah1) with the following command: $ make stack-up
Then try opening http://localhost:3333/v1/resources/http%3A%2F%2Frdfh.ch%2F0803%2Fc5058f3a in a web browser. You should see a response in JSON describing a book.
Note: To delete the existing containers and for a clean start, before creating the knora-test repository explained in the first step above, run the following:
$ make stack-down-delete-volumes
This stops the knora-stack and deletes any created volumes (deletes the database!).
To only shut down the Knora-Stack without deleting the containers:
$ make stack-down
To restart the knora-api use the following command:
$ make stack-restart-api
If a change is made to knora-api code, only its image needs to be rebuilt. In that case, use
$ make stack-up-fast
which starts the knora-stack by skipping rebuilding most of the images (only api image is rebuilt).
To work on Metadata, use
$ make stack-up-with-metadata
which will put three example metadata sets to the projects anything, images and dokubib.
This data can then be consumed from localhost:3333/v2/metadata/http%3A%2F%2Frdfh.ch%2Fprojects%2F0001, localhost:3333/v2/metadata/http%3A%2F%2Frdfh.ch%2Fprojects%2F00FF and localhost:3333/v2/metadata/http%3A%2F%2Frdfh.ch%2Fprojects%2F0804.
Managing Containers in Docker Dashboard
The Docker Desktop is installed on your computer during the installation of docker, it enables easy management of docker containers and access to Docker Hub. To manage your docker containers, docker desktop provides a dashbord.

In docker dashboard, you can see all the running containers, stop, start, restart, or completely delete them. For example, when you start the knora-stack as explained above, in the docker dashboard you will see following:

Access the logs
To read information logged out of any container (db, api, etc.), click on the container in the dashboard and choose 
logs. The example, below shows the logs of the database (db) container that includes the last SPARQL query sent to the
 triplestore. 

Note that, you can also print out the log information directly from the command line. For example, the same logs of the database container can be printed out using the following command:
$ make stack-logs-db
Similarly, the logs of the other containers can be printed out by running make with stack-logs-api, stack-logs-sipi, 
or stack-logs-redis. These commands print out and follow the logs, to only print the logs out without following, use 
-no-follow version of the commands for example:
$ make stack-logs-db-no-follow
Lastly, to print out the entire logs of the running knora-stack, use
$ make stack-logs
Running the automated tests
To run all test targets, use the following in the command line:
$ make test
To run only the dsp-api integration tests, use
$ make test-it
To run only the dsp-api unit tests, use
$ make test-unit
Lastly, to run all dsp-api test, use
$ make test-webapi 
As explained in the bazel document, to run a single test from the command line, for example SearchV1R2RSpec, 
run the following:
bash
    $ bazel test //webapi/src/test/scala/org/knora/webapi/e2e/v1:SearchV1R2RSpec
Note: to run tests, the api container must be stopped first!
Build and Publish Documentation
First, you need to install the requirements through:
$ make docs-install-requirements
Then, to build docs into the local site folder, run the following command:
$ make docs-build
At this point, you can serve the docs to view them locally using
$ make docs-serve
Lastly, to build and publish docs to Github Pages, use
$ make docs-publish
Build and Publish Docker Images
To build and publish all Docker images locally
$ make docker-build 
To publish all Docker images to Dockerhub
$ make docker-publish
Load Testing on Mac OS X
To test Knora with many concurrent connections on Mac OS
X, you will need to adjust some kernel parameters to allow more open
connections, to recycle ephemeral ports more quickly, and to use a wider
range of ephemeral port numbers. The script
webapi/scripts/macOS-kernel-test-config.sh will do this.
Continuous Integration
For continuous integration testing, we use Github CI Actions. Every commit pushed to the git repository or every pull request, triggers the build. Additionally, in Github there is a small checkmark beside every commit, signaling the status of the build (successful, unsuccessful, ongoing).
The build that is executed on Github CI Actions is defined in
.github/workflows/main.yml.
Webapi Server Startup-Flags
The Webapi-Server can be started with a number of flags.
loadDemoData - Flag
When the webapi-server is started with the loadDemoData flag, then at
startup, the data which is configured in application.conf under the
app.triplestore.rdf-data key is loaded into the triplestore, and any
data in the triplestore is removed beforehand.
allowReloadOverHTTP - Flag
When the webapi.server is started with the allowReloadOverHTTP flag (reStart -r),
then the v1/store/ResetTriplestoreContent route is activated. This
route accepts a POST request, with a JSON payload consisting of the
following example content:
[
  {
    "path": "knora-ontologies/knora-base.ttl",
    "name": "http://www.knora.org/ontology/knora-base"
  },
  {
    "path": "knora-ontologies/salsah-gui.ttl",
    "name": "http://www.knora.org/ontology/salsah-gui"
  },
  {
    "path": "test_data/ontologies/incunabula-onto.ttl",
    "name": "http://www.knora.org/ontology/0803/incunabula"
  },
  {
    "path": "test_data/all_data/incunabula-data.ttl",
    "name": "http://www.knora.org/data/incunabula"
  }
]
This content corresponds to the payload sent with the
ResetTriplestoreContent message, defined inside the
org.knora.webapi.messages.v1.store.triplestoremessages package. The
path being the relative path to the ttl file which will be loaded
into a named graph by the name of name.