Skip to content

Commit

Permalink
added the ability to run docker
Browse files Browse the repository at this point in the history
  • Loading branch information
jamesgreen-moj committed Dec 5, 2023
1 parent e098a20 commit a1285ff
Show file tree
Hide file tree
Showing 7 changed files with 76 additions and 67 deletions.
2 changes: 1 addition & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,6 @@ env/
*.sha256
terraform.tfstate

test_data/**.csv
data_src/**.csv
./idea/*
**/__pycache__/
72 changes: 14 additions & 58 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,64 +1,20 @@
# Ministry of Justice Template Repository
# Juniper mist integration script

[![repo standards badge](https://img.shields.io/endpoint?labelColor=231f20&color=005ea5&style=for-the-badge&label=MoJ%20Compliant&url=https%3A%2F%2Foperations-engineering-reports.cloud-platform.service.justice.gov.uk%2Fapi%2Fv1%2Fcompliant_public_repositories%2Fendpoint%2Ftemplate-repository&logo=)](https://operations-engineering-reports.cloud-platform.service.justice.gov.uk/public-report/template-repository)
This repo has been developed by the DevOps Lan&Wi-Fi to automate site creation on juniper mist.

This template repository equips you with the default initial files required for a Ministry of Justice GitHub repository.
## Run script

## Included Files
## Development setup

The repository comes with the following preset files:
### Prerequisites
* Docker
* IDE that integrates with docker (We use IntelliJ in this example)

- LICENSE
- .gitignore
- CODEOWNERS
- dependabot.yml
- GitHub Actions example file
- Ministry of Justice Compliance Badge (Public repositories only)
### Setup
* Run `make build-dev`
* Integrate built docker container with IDE. [here](https://www.jetbrains.com/help/idea/configuring-remote-python-sdks.html#2546d02c) is the example for intelliJ
* mark src directory & test directory within the IDE. [here](https://www.jetbrains.com/help/idea/content-roots.html)

## Setup Instructions

Once you've created your repository using this template, ensure the following steps:

### Update README

Edit this README.md file to document your project accurately. Take the time to create a clear, engaging, and informative README.md file. Include information like what your project does, how to install and run it, how to contribute, and any other pertinent details.

### Update repository description

After you've created your repository, GitHub provides a brief description field that appears on the top of your repository's main page. This is a summary that gives visitors quick insight into the project. Using this field to provide a succinct overview of your repository is highly recommended.

This description and your README.md will be one of the first things people see when they visit your repository. It's a good place to make a strong, concise first impression. Remember, this is often visible in search results on GitHub and search engines, so it's also an opportunity to help people discover your project.

### Grant Team Permissions

Assign permissions to the appropriate Ministry of Justice teams. Ensure at least one team is granted Admin permissions. Whenever possible, assign permissions to teams rather than individual users.

### Read about the GitHub repository standards

Familiarise yourself with the Ministry of Justice GitHub Repository Standards. These standards ensure consistency, maintainability, and best practices across all our repositories.

You can find the standards [here](https://operations-engineering.service.justice.gov.uk/documentation/services/repository-standards.html).

Please read and understand these standards thoroughly and enable them when you feel comfortable.

### Modify the GitHub Standards Badge

Once you've ensured that all the [GitHub Repository Standards](https://operations-engineering.service.justice.gov.uk/documentation/services/repository-standards.html) have been applied to your repository, it's time to update the Ministry of Justice (MoJ) Compliance Badge located in the README file.

The badge demonstrates that your repository is compliant with MoJ's standards. Please follow these [instructions](https://operations-engineering.service.justice.gov.uk/documentation/runbooks/services/add-repo-badge.html) to modify the badge URL to reflect the status of your repository correctly.

**Please note** the badge will not function correctly if your repository is internal or private. In this case, you may remove the badge from your README.

### Manage Outside Collaborators

To add an Outside Collaborator to the repository, follow the guidelines detailed [here](https://github.com/ministryofjustice/github-collaborators).

### Update CODEOWNERS

(Optional) Modify the CODEOWNERS file to specify the teams or users authorized to approve pull requests.

### Configure Dependabot

Adapt the dependabot.yml file to match your project's [dependency manager](https://docs.github.com/en/code-security/dependabot/dependabot-version-updates/configuration-options-for-the-dependabot.yml-file#package-ecosystem) and to enable [automated pull requests for package updates](https://docs.github.com/en/code-security/supply-chain-security).

If your repository is private with no GitHub Advanced Security license, remove the .github/workflows/dependency-review.yml file.
# Notes
* To see options run `make help`
* If you update [requirements.txt](src/requirements.txt), you will need to rebuild the docker container.
File renamed without changes.
13 changes: 10 additions & 3 deletions Dockerfile → docker/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -4,14 +4,21 @@ FROM python:3.11.5
WORKDIR /app

# Copy the current directory contents into the container at /app
COPY . /app
COPY ../src/requirements.txt /tmp/requirements.txt

# Copy entrypoint
COPY docker/entrypoint.sh /entrypoint.sh
COPY src/ /app/src

# Make entrypoint executable
RUN chmod +x /entrypoint.sh

# Install any needed packages specified in requirements.txt
RUN pip install --no-cache-dir -r src/requirements.txt
RUN pip install --no-cache-dir -r ../tmp/requirements.txt

# Set the src directory
ENV PYTHONPATH=/app/src

# Run tests when the container launches
CMD ["python", "-m", "unittest", "discover", "-s", "/app", "-t", "/app"]
ENTRYPOINT ["/entrypoint.sh"]

7 changes: 7 additions & 0 deletions docker/entrypoint.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
#!/bin/bash

if [ "$RUN_UNIT_TESTS" = True ] ; then
python -m unittest discover -s /app -t /app
else
python /app/src/main.py
fi
47 changes: 43 additions & 4 deletions makefile
Original file line number Diff line number Diff line change
@@ -1,5 +1,44 @@
docker-build:
docker build -t juniper-mist-tests .
#!make
.DEFAULT_GOAL := help
SHELL := '/bin/bash'

docker-run:
docker run -v src:/app/src -v test:/app/tests juniper-mist-tests
.PHONY: build
build: ## Build the docker container
docker build -t juniper-mist -f docker/Dockerfile .

.PHONO: create-dir
make create-dir: ## Creates a directory for end user to put CSV file into
mkdir data_src;
echo "Please put csv file into data_src then run 'make-prod'";

.PHONY: run-prod
run-prod: ## Run the python script only mounting the host for csv-file.
docker run -v $(shell pwd)/data_src:/data_src \
-e MIST_API_TOKEN=$$MIST_API_TOKEN \
-e ORG_ID=$$ORG_ID \
juniper-mist

.PHONY: run-dev
run-dev: ## Run the python script while mounting the host. This enables using the latest local src code without needing to wait for a container build.
docker run -v $(shell pwd)/src:/app/src \
-v $(shell pwd)/data_src:/data_src \
-e MIST_API_TOKEN=$$MIST_API_TOKEN \
-e ORG_ID=$$ORG_ID \
juniper-mist

.PHONY: tests
tests: ## Run unit tests for the python app
docker run -v $(shell pwd)/src:/app/src \
-v $(shell pwd)/test:/app/test \
-e RUN_UNIT_TESTS=True juniper-mist

.PHONY: shell
shell: ## Make interactive docker container
docker run -it --entrypoint /bin/bash \
-v $(shell pwd)/src:/app/src \
-v $(shell pwd)/test:/app/test \
-v $(shell pwd)/data_src:/data_src \
-e RUN_UNIT_TESTS=True juniper-mist

help:
@grep -h -E '^[a-zA-Z0-9_-]+:.*?## .*$$' $(MAKEFILE_LIST) | sort | awk 'BEGIN {FS = ":.*?## "}; {printf "\033[36m%-30s\033[0m %s\n", $$1, $$2}'
2 changes: 1 addition & 1 deletion src/main.py
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ def add_geocoding_to_json(data):

if __name__ == '__main__':

csv_file_path = os.getcwd() + '/../test_data/sites_with_clients.csv'
csv_file_path = os.getcwd() + '/../data_src/sites_with_clients.csv'

# Convert CSV to valid JSON
json_data_without_geocoding = convert_csv_to_json(csv_file_path)
Expand Down

0 comments on commit a1285ff

Please sign in to comment.