From 59a05f1a64b8c690a5bb76a66288a2757d109e3a Mon Sep 17 00:00:00 2001 From: Ashvith <49021230+asbanger@users.noreply.github.com> Date: Thu, 13 Jul 2023 17:01:06 +0100 Subject: [PATCH] md documentation for local dev environment --- README.md | 4 +- docs/configure_local_dev_environment.md | 134 ++++++++++++++++++++++++ docs/developing_inside_a_container.md | 64 ----------- 3 files changed, 136 insertions(+), 66 deletions(-) create mode 100644 docs/configure_local_dev_environment.md delete mode 100644 docs/developing_inside_a_container.md diff --git a/README.md b/README.md index 96594153b..1cbc86ddc 100644 --- a/README.md +++ b/README.md @@ -54,13 +54,13 @@ You can sign up for an Azure subscription [here](https://azure.microsoft.com/en- ## Deployment Configuration -The deployment process for the IA Accelerator, uses a concept of **Developing inside a Container** to containerize all the necessary pre-requisite component without requiring them to be installed on the local machine. The environment you will work in will be created using a development container, or dev container, hosted on a virtual machine using GitHub Codespaces. +The deployment process for the IA Accelerator, uses a concept of **Developing inside a Container** to containerize all the necessary pre-requisite component without requiring them to be installed on the local machine. The environment you will work in will be created using a development container, or dev container hosted on a virtual machine using GitHub Codespaces. [![Open in GitHub Codespaces](https://github.com/codespaces/badge.svg)](https://codespaces.new/microsoft/PubSec-Info-Assistant) Begin by setting up your own Codespace using our [Developing in a Codespaces](docs/developing_in_a_codespaces.md) documentation. -*More information can be found at [Developing inside a Container](https://code.visualstudio.com/docs/remote/containers).* +*If you want to configure your local deskop for development container, follow our [Configuring your System for Development Containers](/docs/configure_local_dev_environment.md) guide. More information can be found at [Developing inside a Container](https://code.visualstudio.com/docs/remote/containers).* Once you have the completed the setting up Codespaces, please move on to the Sizing Estimation step. diff --git a/docs/configure_local_dev_environment.md b/docs/configure_local_dev_environment.md new file mode 100644 index 000000000..1f2df238a --- /dev/null +++ b/docs/configure_local_dev_environment.md @@ -0,0 +1,134 @@ +# Configuring your System for Development Containers + +* [Getting started with development containers](#getting-started-development-containers) +* [Install the Prerequisite Software](#Install-the-prerequisite-software) +* [Setting up Docker Desktop for Windows with WSL 2](#setting-up-docker-desktop-for-Windows-with-WSL-2) + * [Configure WSL2 Backend for Docker Containers](#configure-wsl2-backend-for-docker-containers) + * [Connect to Ubuntu WSL with VSCode](#Connect-to-ubuntu-wsl-with-vscode) + * [Configure Git in Ubuntu WSL environment](#configure-Git-in-Ubuntu-WSL-environment) +* [Install Azure CLI on WSL](#install-azure-cli-on-wsl) +* [Configure Local Development Environment](configure-local-development-environment) + +--- +## Getting started with development containers +The Visual Studio Code Dev Containers extension lets you use a container as a full-featured development environment. It allows you to open any folder inside (or mounted into) a container and take advantage of Visual Studio Code's full feature set. A devcontainer.json file in your project tells VS Code how to access (or create) a development container with a well-defined tool and runtime stack. This container can be used to run an application or to separate tools, libraries, or runtimes needed for working with a codebase. + +*More information can be found at [Developing inside a Container](https://code.visualstudio.com/docs/remote/containers).* + +--- +## Install the Pre-Requisite Software + +Install the following software on the machine you will perform the deployment from: + +>1. [Windows Store Ubuntu 22.04 LTS](https://apps.microsoft.com/store/detail/ubuntu-22042-lts/9PN20MSR04DW) +>2. [Docker Desktop](https://www.docker.com/products/docker-desktop) +>3. [Visual Studio Code](https://visualstudio.microsoft.com/downloads/) +>4. [Remote-Containers VS Code Extension](vscode:extension/ms-vscode-remote.remote-containers) +>5. [Git for Windows](https://gitforwindows.org/) + +--- + +## Setting up Docker Desktop for Windows with WSL 2 + +Docker Desktop for Windows provides a development environment for building, shipping, and running dockerized apps. By enabling the WSL 2 based engine, you can run both Linux and Windows containers in Docker Desktop on the same machine. + +### Configure WSL2 Backend for Docker Containers + +To enable **Developing inside a Container** you must configure the integration between Docker Desktop and Ubuntu on your machine. + +>1. Launch Docker Desktop +>2. Open **Settings > General**. Make sure the *Use the WSL 2 based engine" is enabled. +>3. Navigate to **Settings > Resources > WSL INTEGRATION**. +> - Ensure *Enable Integration with my default WSL distro" is enabled. +> - Enable the Ubuntu-22.04 option. +>4. Select **Apply & Restart** + + +### Connect to Ubuntu WSL with VSCode + +Now that Docker Desktop and Ubuntu are integrated, we want to Access the Ubuntu bash prompt from inside VSCode. + +>1. Launch VSCode. +>2. Select **View > Terminal**. A new window should open along the bottom of the VSCode window. +>3. From this windows use the **Launch Profile** dropdown to open the **Ubuntu 22.04 (WSL)** terminal. ![image](images/vscode_terminal_windows.png) +>4. A bash prompt should open in the format `{username}@{machine_name}:/mnt/c/Users/{username}$` + +Once this is complete, you are ready to configure Git for your Ubuntu WSL environment. + + +### Configure Git in Ubuntu WSL environment + +The next step is to configure Git for your Ubuntu WSL environment. We will use the bash prompt from the previous step to issue the following commands: + +Set Git User Name and Email + +``` bash + git config --global user.name "Your Name" + git config --global user.email "youremail@yourdomain.com" +``` + +Set Git [UseHttps](https://github.com/microsoft/Git-Credential-Manager-Core/blob/main/docs/configuration.md#credentialusehttppath) + +``` bash + git config --global credential.useHttpPath true +``` + +Configure Git to use the Windows Host Credential Manager + +``` bash +git config --global credential.helper "/mnt/c/Program\ Files/Git/mingw64/bin/git-credential-manager-core.exe" +``` + +--- +## Install Azure CLI On WSL + +In your Ubuntu 22.04(WSL) terminal from the previous step, follow the directions [here](https://docs.microsoft.com/en-us/cli/azure/install-azure-cli-linux) to install Azure CLI. + +--- + +## Configure Local Development Environment + +Follow these steps to get the accelerator up and running in a subscription of your choice. + +### Clone Repo + +The first step will be to clone the Git repo into your Ubuntu 18.04 WSL environment and, for production deployments, checkout the version that you would like to deploy. For development, stay on main and checkout an appropriate branch. To do this: + +>1. In GitHub, on the Source Tab select **<> Code** and get the HTTPS Clone path. +>2. Launch VSCode. Open the Ubunut 22.04(WSL) Terminal. +>3. Run the following command from the bash command prompt +> +> ``` bash +> git clone info-assist +> cd info-assist +> git fetch --tags +> git checkout tags/ +> ``` +> + +This will now have created the **info-assist** folder on your Ubuntu 22.04 WSL environemnt. + +--- + +### Open Code in Development Container + +The next step is to open the source code and build the dev container. To do this you will: + +1. Log into Azure using the Azure CLI +2. Open the cloned source code into VSCode +3. Launch and connect to the development container from VSCode + +--- +### Important: Rebuild Development container + + + When using any new version of Info Assistant code base from the repo, be sure to rebuild your development container. + + A new popup should appear in VS Code to rebuild the container. If the popup does not appear you can also do the following: + +- Control + Shift + P +- Type Rebuild and select "Dev Containers: Rebuild Container" + +--- +This step is complete, please continue on to the next step [Configuring your Development Environment for PS Info Assistant](./development_environment.md) section and complete the next step. + diff --git a/docs/developing_inside_a_container.md b/docs/developing_inside_a_container.md deleted file mode 100644 index e3c2e9d1f..000000000 --- a/docs/developing_inside_a_container.md +++ /dev/null @@ -1,64 +0,0 @@ -# Configuring your System for Development Containers - -## Install the Pre-Requisite Software - -Install the following software on the machine you will perform the deployment from: - ->1. [Windows Store Ubuntu 22.04 LTS](https://apps.microsoft.com/store/detail/ubuntu-22042-lts/9PN20MSR04DW) ->2. [Docker Desktop](https://www.docker.com/products/docker-desktop) ->3. [Visual Studio Code](https://visualstudio.microsoft.com/downloads/) ->4. [Remote-Containers VS Code Extension](vscode:extension/ms-vscode-remote.remote-containers) ->5. [Git for Windows](https://gitforwindows.org/) - -## Configure WSL2 Backend for Docker Containers - -To enable **Developing inside a Container** you must configure the integration between Docker Desktop and Ubuntu on your machine. - ->1. Launch Docker Desktop ->2. Open **Settings > General**. Make sure the *Use the WSL 2 based engine" is enabled. ->3. Navigate to **Settings > Resources > WSL INTEGRATION**. -> - Ensure *Enable Integration with my default WSL distro" is enabled. -> - Enable the Ubuntu-22.04 option. ->4. Select **Apply & Restart** - -## Connect to Ubuntu WSL with VSCode - -Now that Docker Desktop and Ubuntu are integrated, we want to Access the Ubuntu bash prompt from inside VSCode. - ->1. Launch VSCode. ->2. Select **View > Terminal**. A new window should open along the bottom of the VSCode window. ->3. From this windows use the **Launch Profile** dropdown to open the **Ubuntu 22.04 (WSL)** terminal. ![image](images/vscode_terminal_windows.png) ->4. A bash prompt should open in the format `{username}@{machine_name}:/mnt/c/Users/{username}$` - -Once this is complete, you are ready to configure Git for your Ubuntu WSL environment. - -## Configure Git in Ubuntu WSL environment - -The next step is to configure Git for your Ubuntu WSL environment. We will use the bash prompt from the previous step to issue the following commands: - -Set Git User Name and Email - -``` bash - git config --global user.name "Your Name" - git config --global user.email "youremail@yourdomain.com" -``` - -Set Git [UseHttps](https://github.com/microsoft/Git-Credential-Manager-Core/blob/main/docs/configuration.md#credentialusehttppath) - -``` bash - git config --global credential.useHttpPath true -``` - -Configure Git to use the Windows Host Credential Manager - -``` bash -git config --global credential.helper "/mnt/c/Program\ Files/Git/mingw64/bin/git-credential-manager-core.exe" -``` - -## Install Azure CLI On WSL - -In your Ubuntu 22.04(WSL) terminal from the previous step, follow the directions [here](https://docs.microsoft.com/en-us/cli/azure/install-azure-cli-linux) to install Azure CLI. - ---- - -This step is complete, please continue on to the next step [Configuring your Development Environment for PS Info Assistant](./development_environment.md) section and complete the next step.