-
Notifications
You must be signed in to change notification settings - Fork 209
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Dev containers #1228
Dev containers #1228
Changes from 46 commits
c77f716
b076ea3
96d333b
151bc2d
05cf1c4
0d65aac
a3d22ca
952583a
9a1fb06
ad189c5
fffe9c7
ed8e300
95e0aab
fb5c61b
4fc5fc3
b54eacd
5a6e210
8abaa7b
a2f570e
9f4a0bf
928195e
d50db33
781f8ee
d6188d2
49e5c5f
4117756
9a5dc0f
07590df
9629a2e
fc27e5a
a0ba73a
e1c4054
bc4e8fb
52e5fce
4d98000
c610ddc
9c983ca
c5c823f
68bb45d
dca591b
6effd98
d793625
05e692d
4d659a3
1420450
c8654cf
e03d724
57900e7
afd9712
4760a39
c931b51
1c3e3f4
65c1ca3
3106356
5c96022
0c042a0
ee987ba
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,12 @@ | ||
// SPDX-FileCopyrightText: PyPSA-Earth and PyPSA-Eur Authors | ||
// | ||
// SPDX-License-Identifier: CC-BY-4.0 | ||
// For format details, see https://aka.ms/devcontainer.json. | ||
{ | ||
"name": "pypsa earth dev", | ||
"image": "ghcr.io/drifter089/pypsa-earth:latest", | ||
"workspaceMount": "source=${localWorkspaceFolder},target=/workspaces,type=bind,consistency=cached", | ||
"initializeCommand": "docker pull ghcr.io/drifter089/pypsa-earth:latest", | ||
"workspaceFolder": "/workspaces", | ||
"postAttachCommand": "bash .devcontainer/setup.sh" | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
# SPDX-FileCopyrightText: PyPSA-Earth and PyPSA-Eur Authors | ||
# | ||
# SPDX-License-Identifier: CC-BY-4.0 | ||
#!/bin/sh | ||
|
||
cat .devcontainer/welcome-message.txt |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
# SPDX-FileCopyrightText: PyPSA-Earth and PyPSA-Eur Authors | ||
# | ||
# SPDX-License-Identifier: CC-BY-4.0 | ||
|
||
|
||
|
||
👋 Welcome to the PyPSA-Earth Development Environment! | ||
|
||
We’re excited to have you here! This setup allows you to contribute to PyPSA-Earth effortlessly using a development container in VS Code. | ||
|
||
ekatef marked this conversation as resolved.
Show resolved
Hide resolved
|
||
📖 Getting Started for New Users | ||
|
||
• For a step-by-step guide on setting up your environment, debugging, and making your first contribution, refer to the PyPSA-Earth README. It covers everything you need to know as a newcomer. | ||
• The configuration files for the development container are located in the .github/.devcontainer folder. | ||
|
||
💡 Tips for New Users | ||
|
||
• Make the most of VS Code by using the Command Palette (Cmd/Ctrl + Shift + P or F1) for quick access to features and commands. | ||
• If you’re new to development containers, learn the basics at containers.dev. | ||
|
||
🚀 Start Exploring and Happy Coding! | ||
|
||
Don’t hesitate to reach out if you need help—our community is here to support you. | ||
ekatef marked this conversation as resolved.
Show resolved
Hide resolved
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
// For format details, see https://aka.ms/devcontainer.json. For config options, see the | ||
// README at: https://github.com/devcontainers/templates/tree/main/src/ubuntu | ||
{ | ||
"name": "pypsa earth dev", | ||
"build": { | ||
"dockerfile": "../../Dockerfile" | ||
}, | ||
|
||
"features": { | ||
"ghcr.io/devcontainers-contrib/features/bash-command:1": {}, | ||
"ghcr.io/eliises/devcontainer-features/bash-profile:1": {} | ||
}, | ||
"customizations": { | ||
"vscode": { | ||
"terminal.integrated.profiles.linux": { | ||
"bash": { | ||
"path": "/bin/bash" | ||
} | ||
}, | ||
"extensions": [ | ||
"ms-python.python", | ||
"ms-python.vscode-pylance", | ||
"ms-azuretools.vscode-docker", | ||
"ms-toolsai.jupyter", | ||
"zainchen.json", | ||
"tomoki1207.pdf", | ||
"grapecity.gc-excelviewer" | ||
] | ||
} | ||
}, | ||
|
||
"postCreateCommand": "python -m pip install --upgrade debugpy" | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
name: Dev Container Build and Push Image | ||
|
||
on: | ||
workflow_dispatch: | ||
push: | ||
branches: [main] | ||
paths: | ||
- envs/linux-pinned.yaml | ||
|
||
jobs: | ||
build: | ||
runs-on: ubuntu-latest | ||
|
||
steps: | ||
- name: Checkout | ||
id: checkout | ||
uses: actions/checkout@v1 | ||
|
||
- name: Login to GitHub Container Registry | ||
uses: docker/login-action@v2 | ||
with: | ||
registry: ghcr.io | ||
username: ${{ secrets.REGISTRY_USER }} | ||
password: ${{ secrets.REGISTRY_TOKEN }} | ||
|
||
- name: Build Dev Container Image | ||
uses: devcontainers/[email protected] | ||
with: | ||
subFolder: .github | ||
cacheFrom: ghcr.io/${{ github.repository }}-dev-env | ||
imageName: ghcr.io/${{ github.repository }}-dev-env | ||
push: always | ||
# noCache: true | ||
ekatef marked this conversation as resolved.
Show resolved
Hide resolved
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,54 @@ | ||
<!-- | ||
SPDX-FileCopyrightText: PyPSA-Earth and PyPSA-Eur Authors | ||
|
||
SPDX-License-Identifier: AGPL-3.0-or-later | ||
--> | ||
# PyPSA-Earth Development Environment Setup with Docker | ||
|
||
This guide provides an alternative way to set up a development environment for **PyPSA-Earth** using Docker containers. This method is particularly useful for users who are not familiar with programming or Python, or who prefer not to install Python directly on their local machine. Using Docker simplifies setup by creating a self-contained environment for PyPSA-Earth. | ||
|
||
ekatef marked this conversation as resolved.
Show resolved
Hide resolved
|
||
## Prerequisites | ||
|
||
### 1. Install Docker | ||
|
||
Ensure Docker is installed on your system. Follow the instructions for your operating system: | ||
|
||
- **Windows**: [Docker for Windows](https://docs.docker.com/desktop/install/windows-install/) | ||
- **Linux**: [Docker for Linux](https://docs.docker.com/desktop/install/linux/) | ||
- **MacOS**: [Docker for MacOS](https://docs.docker.com/desktop/install/mac-install/) | ||
|
||
### 2. Install GitHub Desktop | ||
|
||
You will also need GitHub Desktop to clone the PyPSA-Earth repository. Install GitHub Desktop for your operating system from [here](https://desktop.github.com/download/). | ||
|
||
## Steps to Set Up PyPSA-Earth with Docker | ||
|
||
### Step 1: Clone the Repository | ||
|
||
1. Open **GitHub Desktop**. | ||
2. Go to **File** > **Clone Repository**. | ||
3. Paste the following URL in the URL field: | ||
|
||
```bash | ||
https://github.com/drifter089/pypsa-earth.git | ||
``` | ||
ekatef marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
4. Click on **Clone**. | ||
5. Choose the location where you want to save the repository on your local machine. | ||
6. After cloning, click on **Current Branch: main** and select `devContainers`. | ||
7. Click on **Open in Visual Studio Code**. | ||
|
||
### Step 2: Rebuild and Open in Container | ||
|
||
1. Open the cloned repository in **VSCode**. | ||
2. Click on the green icon in the bottom left corner of the VSCode window. | ||
3. Select **Reopen in Container**. | ||
4. Wait for the container to build and for the repository to open in the container. | ||
|
||
Once these steps are completed, your development environment will be ready, and you can start using **PyPSA-Earth** in the Docker container. | ||
|
||
--- | ||
|
||
You are now all set up! You can use the development environment to explore PyPSA-Earth and make modifications as needed within the Docker container. | ||
|
||
You can start running the tutorial [here](https://pypsa-earth.readthedocs.io/en/latest/short_tutorial.html) |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
# SPDX-FileCopyrightText: PyPSA-Earth and PyPSA-Eur Authors | ||
# | ||
# SPDX-License-Identifier: CC-BY-4.0 | ||
FROM condaforge/mambaforge | ||
|
||
RUN conda update -n base conda | ||
RUN conda install -n base conda-libmamba-solver | ||
RUN conda config --set solver libmamba | ||
|
||
RUN apt-get update && apt-get install -y bash git && apt-get install gcc -y | ||
ekatef marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
WORKDIR /pypsa-earth | ||
|
||
COPY ./envs ./temp | ||
|
||
RUN conda env create -n pypsa-earth -f temp/linux-pinned.yaml | ||
|
||
RUN conda init bash | ||
Comment on lines
+12
to
+18
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. You mean the recent environment issues? A solution has still been found, we only need to align on implementing it (realistically speaking, it should be done by tomorrow European evening) |
||
|
||
RUN touch ~/.bashrc && echo "conda activate pypsa-earth" >> ~/.bashrc | ||
|
||
SHELL ["/bin/bash", "--login", "-c"] | ||
|
||
ENV PATH /opt/conda/envs/pypsa-earth/bin:$PATH | ||
|
||
RUN conda install conda-forge::openjdk -y | ||
|
||
RUN rm -r temp | ||
|
||
RUN conda clean -afy && \ | ||
rm -rf /tmp/* | ||
|
||
CMD ["bash"] |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,49 @@ | ||
.. SPDX-FileCopyrightText: PyPSA-Earth and PyPSA-Eur Authors | ||
.. | ||
.. SPDX-License-Identifier: CC-BY-4.0 | ||
|
||
.. _docker_containers: | ||
|
||
Alternate Installation with Docker | ||
=============================================== | ||
|
||
This is an alternative way to create a development environment for PyPSA-Earth. This method is useful for users who are not familiar with programming or Python, or who do not want to install Python on their local machine. It uses Docker containers to create a development environment for PyPSA-Earth. | ||
|
||
This section provides a step-by-step guide on how to set up and use Docker containers to run PyPSA-Earth. | ||
ekatef marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
Steps: | ||
|
||
1. Install Docker: Follow the instructions for your operating system: | ||
|
||
* `Windows <https://docs.docker.com/desktop/install/windows-install/>`_ | ||
* `Linux <https://docs.docker.com/desktop/install/linux/>`_ | ||
* `MacOS <https://docs.docker.com/desktop/install/mac-install/>`_ | ||
|
||
Ensure Docker is installed on your system. | ||
|
||
2. Install GitHub Desktop for your OS `here <https://desktop.github.com/download/>`_. | ||
|
||
3. Clone the repository: | ||
* Open GitHub Desktop. | ||
* Click on "File" in the top left corner. | ||
* Click on "Clone Repository". | ||
* Paste the following URL in the URL field: | ||
|
||
.. code:: bash | ||
|
||
https://github.com/drifter089/pypsa-earth.git | ||
|
||
* Click on "Clone". | ||
* Choose the location where you want to save the repository. | ||
* Click on "Current Branch: main" and select `devContainers`. | ||
* Click on "Open in Visual Studio Code". | ||
|
||
The repository will be cloned to your local machine. | ||
|
||
4. Rebuild and open in a container: | ||
* Open the repository in VSCode. | ||
* Click on the green icon in the bottom left corner of the VSCode window. | ||
* Click on "Reopen in Container". | ||
* Wait for the container to build and open the repository in the container. | ||
|
||
The environment will be ready for use. You can now run PyPSA-Earth in the container. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@drifter089 I understand that it has been crucial to test the docker workflow, and thanks a lot for making it work using your personal repo! For the stable implementation, I wonder if can we use
pypsa-earth
repo. Obviously, happy to provide you with all the administrative rights to maintain the docker images. Could it work?