Skip to content

Commit

Permalink
chore: switch to pyproject
Browse files Browse the repository at this point in the history
  • Loading branch information
yeisonvargasf committed Jan 7, 2025
1 parent 9a6619e commit 51c4a90
Show file tree
Hide file tree
Showing 16 changed files with 420 additions and 458 deletions.
67 changes: 46 additions & 21 deletions .devcontainer/Dockerfile
Original file line number Diff line number Diff line change
@@ -1,27 +1,52 @@
# Use the official Python 3.12 slim image
FROM python:3.12-slim
FROM python:3.8-alpine

# Create a non-root user and a directory for the application
RUN useradd -m appuser && \
mkdir /app && \
chown appuser:appuser /app
ENV PYTHONDONTWRITEBYTECODE=1
ENV PYTHONUNBUFFERED=1

# Set the working directory
WORKDIR /app
RUN apk add --no-cache \
git \
curl \
wget \
zsh \
jq \
sudo \
docker \
docker-compose \
bash \
grep \
sed \
# Build dependencies for Python packages
gcc \
musl-dev \
python3-dev \
libffi-dev \
openssl-dev \
cargo \
rust \
make

# Set environment variables in a single step
ENV LC_ALL=C.UTF-8 \
LANG=C.UTF-8 \
PYTHONPATH="/app"
RUN pip install --no-cache-dir uv \
&& uv pip install --system hatch hatch-containers

# Install necessary dependencies, clean up after installation to reduce image size
RUN apt-get update && \
apt-get -y install docker.io jq git && \
apt-get clean && \
rm -rf /var/lib/apt/lists/*
ARG USERNAME=developer
ARG USER_UID=1000
ARG USER_GID=$USER_UID

# Copy project files into the container (relative to the build context)
COPY . /app/
RUN addgroup -g $USER_GID $USERNAME \
&& adduser -u $USER_UID -G $USERNAME -s /bin/zsh -D $USERNAME \
&& echo "$USERNAME ALL=(root) NOPASSWD:ALL" > /etc/sudoers.d/$USERNAME \
&& chmod 0440 /etc/sudoers.d/$USERNAME \
&& addgroup $USERNAME docker

# Switch to the non-root user for security reasons
USER appuser
RUN sh -c "$(curl -fsSL https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/tools/install.sh)"

RUN sed -i 's|/bin/ash|/bin/zsh|' /etc/passwd

RUN cp -r /root/.oh-my-zsh /home/$USERNAME/ \
&& cp /root/.zshrc /home/$USERNAME/ \
&& chown -R $USERNAME:$USERNAME /home/$USERNAME/.oh-my-zsh \
&& chown $USERNAME:$USERNAME /home/$USERNAME/.zshrc

USER $USERNAME

CMD ["zsh"]
73 changes: 57 additions & 16 deletions .devcontainer/devcontainer.json
Original file line number Diff line number Diff line change
@@ -1,19 +1,60 @@
{
"name": "Safety-CLI Dev Container",
"build": {
"dockerfile": "Dockerfile",
"context": "..",
"args": {
"SAFETY_VERSION": "DEV"
"name": "Safety CLI Development Environment",

"build": {
"dockerfile": "Dockerfile",
"context": "."
},

"remoteUser": "developer",
"workspaceFolder": "${localWorkspaceFolder}",
"workspaceMount": "source=${localWorkspaceFolder},target=${localWorkspaceFolder},type=bind",


"mounts": [
"source=/var/run/docker.sock,target=/var/run/docker.sock,type=bind",
"source=${localEnv:HOME}${localEnv:USERPROFILE}/.ssh,target=/home/developer/.ssh,type=bind,consistency=cached"
],

"remoteEnv": {
"PYTHONPATH": "${localWorkspaceFolder}",
"TERM": "xterm-256color"
},

"customizations": {
"vscode": {
"settings": {
"terminal.integrated.defaultProfile.linux": "zsh",
"terminal.integrated.profiles.linux": {
"zsh": {
"path": "/bin/zsh"
}
},
// TODO: Use hatch instead
"python.defaultInterpreterPath": "/usr/local/bin/python",
"python.formatting.provider": "black",
"editor.formatOnSave": true,
"editor.rulers": [88],
"[python]": {
"editor.formatOnSave": true,
"editor.codeActionsOnSave": {
"source.organizeImports": true
}
}
},
"extensions": [
},
"extensions": [
"ms-python.python",
"ms-python.vscode-pylance",
"ms-python.debugpy"
],
"postCreateCommand": "pip install -r test_requirements.txt && pip install ruff requests pre-commit",
"remoteUser": "root",
"workspaceFolder": "/workspaces/safety",
"forwardPorts": [49152]
}
"ms-python.vscode-pylance"
]
}
},

"postCreateCommand": "git config --global core.editor nano",

"containerEnv": {
"SHELL": "/bin/zsh"
},

"waitFor": "postCreateCommand",
"shutdownAction": "stopContainer"
}
5 changes: 1 addition & 4 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -17,10 +17,7 @@ jobs:

- name: Safety Version
run: |
pip install packaging
package_version=$(cat safety/VERSION)
echo $package_version
echo "SAFETY_VERSION=$package_version" >> $GITHUB_ENV
echo "SAFETY_VERSION=$(python -c 'import tomli; print(tomli.load(open("pyproject.toml", "rb"))["project"]["version"])')" >> $GITHUB_ENV
- name: Extract Major and Minor Version
run: |
Expand Down
Empty file added .github/workflows/ci.yml
Empty file.
1 change: 0 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
# Other
.vscode/
.direnv/
.envrc

Expand Down
Loading

0 comments on commit 51c4a90

Please sign in to comment.