This section explains how to run some of the services using go run
instead of the Docker setup to facilitate development.
- Bring up all SDA services with the S3 backend and populate them with test data by running the following command in the root folder of the repository:
make integrationtest-sda-s3-run
- Change to the folder
sda-download
and start thesda-download
service using:
CONFIGFILE=dev_utils/config-notls_local.yaml go run cmd/main.go
- Check if
sda-download
works as expected using:
curl -o /dev/null -s -w "%{http_code}\n" http://localhost:18080/health
If successful, the curl command should output the HTTP code 200
.
You can further check the endpoint /metadata/datasets
using:
token=$(curl -s -k http://localhost:8080/tokens | jq -r '.[0]')
curl -H "Authorization: Bearer $token" http://localhost:18080/metadata/datasets
If successful, the curl command should output a JSON body containing:
["EGAD74900000101"]
Running any of the SDA services located in the sda
subfolder requires that the service specific credentials and RabbitMQ configurations are set as ENVs. Here, we'll use ingest
as an example.
- Bring up all SDA services with the S3 backend by running the following command in the root folder of the repository:
make sda-s3-up
- When the previous command is finished, bring down the
ingest
service using:
docker stop ingest
- Copy keys and other information from the shared folder of the container using:
docker cp verify:/shared /tmp/
This will copy all data from the container's /shared
folder to /tmp/shared
on your local machine, so that we have access to all the auto generated files that will be required.
- Change to the folder
sda
and start theingest
service using:
export BROKER_PASSWORD=ingest
export BROKER_USER=ingest
export BROKER_QUEUE=ingest
export BROKER_ROUTINGKEY=archived
export DB_PASSWORD=ingest
export DB_USER=ingest
CONFIGFILE=config_local.yaml go run cmd/ingest/ingest.go
- Check if the
ingest
service works as expected by following these steps
# create a test file
seq 10 > /tmp/t1.txt
# update the s3cmd config file
sed -i '/host_/s/s3inbox:8000/localhost:18000/g' /tmp/shared/s3cfg
# upload /tmp/t1.txt to s3inbox by sda-cli
sda-cli -config /tmp/shared/s3cfg upload -encrypt-with-key /tmp/shared/c4gh.pub.pem /tmp/t1.txt
# use sda-admin to check if t1.txt has been uploaded
export API_HOST=http://localhost:8090
export ACCESS_TOKEN=$(curl -s -k http://localhost:8080/tokens | jq -r '.[0]')
sda-admin file list -user test@dummy.org # file test_dummy.org/t1.txt.c4gh should have fileStatus 'uploaded'
# register the Crypt4GH key
curl -H "Authorization: Bearer $ACCESS_TOKEN" -H "Content-Type: application/json" -X POST -d '{"pubkey": "'"$( base64 -w0 /tmp/shared/c4gh.pub.pem)"'", "description": "pubkey"}' http://localhost:8090/c4gh-keys/add
# use sda-admin to ingest the file t1.txt
sda-admin file ingest -filepath test_dummy.org/t1.txt.c4gh -user test@dummy.org
# verify that t1.txt has been ingested using sda-admin
sda-admin file list -user test@dummy.org # file test_dummy.org/t1.txt.c4gh should have fileStatus 'verified'