Skip to content

Commit

Permalink
Make docker and docker-compose work on WSL2 (#1375)
Browse files Browse the repository at this point in the history
### Summary
> Describe your changes.

Fixes the docker-compose steps to work on WSL2 (Windows Subsystem for
Linux 2) and OSX. Updates documentation to use the new cncf tag when
building the container.

docker-compose is very helpful for dev setups and trying out
cartography.

### Checklist

### Testing performed
I started with a fresh clone of this branch and on _both_ OSX and
WSL2ran

1. `docker build -t cartography-cncf/cartography-dev -f dev.Dockerfile
./`
1. `docker-compose run cartography-dev make test`

I can confirm that both paths worked and ran the full test suite using
docker-compose.

#### WSL2
Linter:

![image](https://github.com/user-attachments/assets/b165feb6-0d0a-4a9c-90dd-fe47e8390b0d)

Unit tests: 

![image](https://github.com/user-attachments/assets/4cfa8a41-6775-4ac1-ad9c-6052163c0a17)

Integration tests:

![image](https://github.com/user-attachments/assets/f134dec5-8df2-4c9b-a7f6-57cccac51f89)

#### OSX
Linter:
<img width="1000" alt="Screenshot 2024-11-03 at 12 29 49 AM"
src="https://github.com/user-attachments/assets/e7840c2a-8065-4163-8057-3de902532291">

Unit tests:
<img width="997" alt="Screenshot 2024-11-03 at 12 30 07 AM"
src="https://github.com/user-attachments/assets/11d91723-776c-4438-b2a1-fe783e75e414">

Integration tests:
<img width="1003" alt="Screenshot 2024-11-03 at 12 30 22 AM"
src="https://github.com/user-attachments/assets/c2360ad5-a2c2-4309-91d0-1080dc9d0bb3">

---------

Signed-off-by: Alex Chantavy <achantavy@lyft.com>
  • Loading branch information
Alex Chantavy authored Nov 5, 2024
1 parent 5029b00 commit 9f15fc3
Show file tree
Hide file tree
Showing 8 changed files with 51 additions and 34 deletions.
5 changes: 5 additions & 0 deletions .cache/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
# This .gitignore is a placeholder so that we can store .cache/ in github.
# We are including a pre-created .cache in Github so that when
# we run docker-compose in WSL2 during dev linting, WSL2 does not attempt
# to create .cache/ with root as the owner. The contents of .cache
# should never be pushed back upstream to the main cartography repo.
7 changes: 4 additions & 3 deletions .env
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
# This file is for use with docker compose so that mounting Neo4j volumes doesn't fail with perms errs
GID=10001
UID=10001
# This file is for docker-compose dev use so that mounting
# Neo4j volumes doesn't fail with permissions errors.
GID=1000
UID=1000
1 change: 1 addition & 0 deletions Dockerfile
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
# This is a thin distribution of the cartography software.
# It is published at ghcr.io.
FROM python:3.10-slim

# the UID and GID to run cartography as
Expand Down
35 changes: 20 additions & 15 deletions dev.Dockerfile
Original file line number Diff line number Diff line change
@@ -1,28 +1,33 @@
# Builds cartography container for development by performing a Python editable install of the current source code.
# This image is for dev only.
# Performs a Python editable install of the current Cartography source.
# Assumptions:
# - This dockerfile will get called with .cache as a volume mount.
# - The current working directory on the host building this container
# is the cartography source tree from github.
FROM python:3.10-slim

# the UID and GID to run cartography as
# (https://github.com/hexops/dockerfile#do-not-use-a-uid-below-10000).
ARG uid=10001
ARG gid=10001
# The UID and GID to run cartography as.
# This needs to match the gid and uid on the host.
# Update this to match. On WSL2 this is usually 1000.
ARG uid=1000
ARG gid=1000

RUN apt-get update && \
DEBIAN_FRONTEND=noninteractive apt-get install -y --no-install-recommends make git && \
apt-get clean && \
rm -rf /var/lib/apt/lists/*

# Assumption: current working directory is the cartography source tree from github.
COPY . /var/cartography
# Install dependencies.
WORKDIR /var/cartography
ENV HOME=/var/cartography
COPY . /var/cartography
RUN pip install -r test-requirements.txt && \
pip install -U -e . && \
chmod -R a+w /var/cartography

RUN pip install -U -e . && \
pip install -r test-requirements.txt && \
# Grant write access to the directory for unit and integration test coverage files
chmod -R a+w /var/cartography && \
# Sets the directory as safe due to a mismatch in the user that cloned the repo
# and the user that is going to run the unit&integ tests. This lets pre-commit work.
git config --global --add safe.directory /var/cartography && \
# Now copy the entire source tree.
ENV HOME=/var/cartography
# Necessary for pre-commit.
RUN git config --global --add safe.directory /var/cartography && \
git config --local user.name "cartography"

USER ${uid}:${gid}
16 changes: 10 additions & 6 deletions docker-compose.yml
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,6 @@ services:
- ./.compose/neo4j/import:/import
- ./.compose/neo4j/logs:/logs
- ./.compose/neo4j/plugins:/plugins
user: "${UID}:${GID}"
environment:
# Raise memory limits:
- NEO4J_dbms_memory_pagecache_size=1G
Expand All @@ -34,14 +33,15 @@ services:
# Networking:
- dbms.connector.bolt.listen_address=0.0.0.0:7687
healthcheck:
test: ["CMD", "curl", "-f", "http://localhost:7474"]
test: ["CMD", "wget", "--no-verbose", "http://localhost:7474"]
interval: 10s
timeout: 10s
retries: 10

# Runs the standard cartography image available at ghcr.io.
cartography:
image: ghcr.io/lyft/cartography:latest
image: ghcr.io/cartography-cncf/cartography:latest
platform: linux/x86_64
# EXAMPLE: Our ENTRYPOINT is cartography, running specific command to sync AWS
# command: ["-v", "--neo4j-uri=bolt://neo4j:7687", "--aws-sync-all-profiles"]
init: true
Expand All @@ -50,6 +50,7 @@ services:
- neo4j
volumes:
# Provide AWS creds to the container
# Add other volumes here to support other data providers.
- ~/.aws:/var/cartography/.aws/
environment:
# Point to the neo4j service defined in this docker-compose file.
Expand All @@ -58,9 +59,8 @@ services:
# Intended to run local automated tests, custom sync scripts, and local changes.
cartography-dev:
# See dev instructions: we assume that you have built this with
# `docker build -t lyft/cartography-dev . -f dev.Dockerfile`.
# Do not push this image remotely!
image: lyft/cartography-dev
# `docker build -t cartography-cncf/cartography-dev -f dev.Dockerfile ./`
image: cartography-cncf/cartography-dev
init: true
restart: on-failure
depends_on:
Expand All @@ -71,6 +71,10 @@ services:
# For pre-commit to work
- .:/var/cartography
- ./.cache/pre-commit:/var/cartography/.cache/pre-commit
# for git, for precommit
- ./.git:/var/cartography/.git
environment:
# Point to the neo4j service defined in this docker-compose file.
- NEO4J_URL=bolt://cartography-neo4j-1:7687
# this is actually needed
- PRE_COMMIT_HOME=/var/cartography/.cache
15 changes: 7 additions & 8 deletions docs/root/dev/developer-guide.md
Original file line number Diff line number Diff line change
Expand Up @@ -99,8 +99,7 @@ We include a dev.Dockerfile that can help streamline common dev tasks. It is dif
To use it, build dev.Dockerfile with
```bash
cd /path/to/cartography/repo
docker build -t lyft/cartography-dev -f . dev.Dockerfile
docker-compose --profile dev up -d
docker build -t cartography-cncf/cartography-dev -f dev.Dockerfile ./
```

With that, there are some interesting things you can do with it.
Expand Down Expand Up @@ -137,7 +136,7 @@ If you don't like docker-compose or if it doesn't work for you for any reason, h
#### Run unit tests with dev.Dockerfile

```bash
docker run --rm lyft/cartography-dev make test_unit
docker run --rm cartography-cncf/cartography-dev make test_unit
```

This is a simple command because it doesn't require any volume mounts or docker networking.
Expand All @@ -148,7 +147,7 @@ This is a simple command because it doesn't require any volume mounts or docker
docker run --rm \
-v $(pwd):/var/cartography \
-v $(pwd)/.cache/pre-commit:/var/cartography/.cache/pre-commit \
lyft/cartography-dev \
cartography-cncf/cartography-dev \
make test_lint
```

Expand All @@ -173,7 +172,7 @@ and then call the integration test suite like this:
docker run --rm \
--network cartography-network \
-e NEO4J_URL=bolt://cartography-neo4j:7687 \
lyft/cartography-dev \
cartography-cncf/cartography-dev \
make test_integration
```

Expand All @@ -200,20 +199,20 @@ docker run --rm \
-v $(pwd)/.cache/pre-commit:/var/cartography/.cache/pre-commit \
--network cartography-network \
-e NEO4J_URL=bolt://cartography-neo4j:7687 \
lyft/cartography-dev \
cartography-cncf/cartography-dev \
make test
```

#### Run a [custom sync script](#implementing-custom-sync-commands) with dev.Dockerfile

```bash
docker run --rm lyft/cartography-dev python custom_sync.py
docker run --rm cartography-cncf/cartography-dev python custom_sync.py
```

#### Run cartography CLI with dev.Dockerfile

```bash
docker run --rm lyft/cartography-dev cartography --help
docker run --rm cartography-cncf/cartography-dev cartography --help
```

## How to write a new intel module
Expand Down
4 changes: 2 additions & 2 deletions docs/root/install.md
Original file line number Diff line number Diff line change
Expand Up @@ -124,7 +124,7 @@ Read on to see [other things you can do with Cartography](#things-to-do-next).
-v ~/.aws:/var/cartography/.aws/ \
-e AWS_PROFILE=1234_testprofile \
-e AWS_DEFAULT_REGION=us-east-1 \
lyft/cartography --neo4j-uri bolt://cartography-neo4j:7687
cartography-cncf/cartography --neo4j-uri bolt://cartography-neo4j:7687
```

If things work, your terminal will look like this where you see log messages displaying how many assets are being loaded to the graph:
Expand All @@ -139,7 +139,7 @@ Read on to see [other things you can do with Cartography](#things-to-do-next).

- `AWS_DEFAULT_REGION` must be specified.
- Our docker-compose.yml maps in `~/.aws/` on your host machine to `/var/cartography/.aws` in the cartography container, so the container has access to AWS profile and credential files.
- You can view a full list of Cartography's CLI arguments by running `docker run lyft/cartography --help`.
- You can view a full list of Cartography's CLI arguments by running `docker run cartography-cncf/cartography --help`.
1. **View the graph.**
Expand Down
2 changes: 2 additions & 0 deletions tests/unit/cartography/intel/github/test_github.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,11 +16,13 @@
from tests.data.github.rate_limit import RATE_LIMIT_RESPONSE_JSON


@patch('cartography.intel.github.util.time.sleep')
@patch('cartography.intel.github.util.handle_rate_limit_sleep')
@patch('cartography.intel.github.util.fetch_page')
def test_fetch_all_handles_retries(
mock_fetch_page: Mock,
mock_handle_rate_limit_sleep: Mock,
mock_sleep: Mock,
) -> None:
'''
Ensures that fetch_all re-reaises the same exceptions when exceeding retry limit
Expand Down

0 comments on commit 9f15fc3

Please sign in to comment.