This document describes how to setup your environment with Python and uv, if you're working on new features or a bug fix for Semantic Kernel, or simply want to run the tests included.
<<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< head <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream
=======
Stashed changes head ======= <<<<<<< main <<<<<<< div main ======= ======= <<<<<<< main origin/main <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= <<<<<<< main Stashed changes ======= <<<<<<< main Stashed changes ======= <<<<<<< main origin/main head ======= <<<<<<< Updated upstream ======= <<<<<<< main ======= <<<<<<< main origin/main Stashed changes Stashed changes
Make sure you have an OpenAI API Key or Azure OpenAI service key
There are two methods to manage keys, secrets, and endpoints:
- Store them in environment variables. SK Python leverages pydantic settings to load keys, secrets, and endpoints. This means that there is a first attempt to load them from environment variables. The
.envfile naming applies to how the names should be stored as environment variables. - If you'd like to use the
.envfile, you will need to configure the.envfile with the following keys into a.envfile (see the.env.examplefile):
OPENAI_API_KEY=""
OPENAI_ORG_ID=""
AZURE_OPENAI_CHAT_DEPLOYMENT_NAME=""
AZURE_OPENAI_TEXT_DEPLOYMENT_NAME=""
AZURE_OPENAI_EMBEDDING_DEPLOYMENT_NAME=""
AZURE_OPENAI_ENDPOINT=""
AZURE_OPENAI_API_KEY=""To get started, you'll need VSCode and a local installation of Python 3.x.
You can run:
python3 --version ; pip3 --version ; code -v
to verify that you have the required dependencies.
Check that you've cloned the repository to ~/workspace or a similar folder.
Avoid /mnt/c/ and prefer using your WSL user's home directory.
chat_completion = OpenAIChatCompletion(service_id="test", env_file_path=<path_to_file>)=======
main ======= <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< head <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream ======= ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes <<<<<<< main ======= ======= origin/main ======= ======= <<<<<<< main ======= ======= Stashed changes ======= <<<<<<< Updated upstream Stashed changes ======= <<<<<<< main ======= ======= Stashed changes <<<<<<< Updated upstream head ======= Stashed changes
Check that you've cloned the repository to ~/workspace or a similar folder.
Avoid /mnt/c/ and prefer using your WSL user's home directory.
<<<<<<< Updated upstream
<<<<<<< div
<<<<<<< div
ms/features/bugbash-prep main ======= ms/features/bugbash-prep <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< head origin/main <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= ======= Stashed changes ======= Stashed changes origin/main head ======= <<<<<<< Updated upstream ======= ms/features/bugbash-prep origin/main Stashed changes Stashed changes
Ensure you have the WSL extension for VSCode installed.
uv allows us to use SK from the local files, without worrying about paths, as if you had SK pip package installed.
To install SK and all the required tools in your system, first, navigate to the directory containing this DEV_SETUP using your chosen shell. <<<<<<< Updated upstream <<<<<<< div <<<<<<< div
<<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< head <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream
<<<<<<< main
Stashed changes ======= <<<<<<< main Stashed changes ======= <<<<<<< main Stashed changes ======= <<<<<<< main Stashed changes ======= <<<<<<< main Stashed changes head ======= <<<<<<< Updated upstream ======= <<<<<<< main Stashed changes Stashed changes
Check the uv documentation for the installation instructions. At the time of writing this is the command to install uv:
powershell -c "irm https://astral.sh/uv/install.ps1 | iex"
```python {"id":"01J6KNPX0HTGAZ4YDQ3625T9E4"}
python3 --version ; pip3 --version ; code -vYou can then run the following commands manually:
# Install Python 3.10, 3.11, and 3.12
uv python install 3.10 3.11 3.12
# Create a virtual environment with Python 3.10 (you can change this to 3.11 or 3.12)
$PYTHON_VERSION = "3.10"
uv venv --python $PYTHON_VERSION
# Install SK and all dependencies
uv sync --all-extras --dev
# Install pre-commit hooks
uv run pre-commit install -c python/.pre-commit-config.yamlOr you can then either install make and then follow the guide for Mac and Linux, or run the following commands, the commands are shown as bash but should work in powershell as well.
It is super simple to get started, run the following commands:
make installThis will install uv, python, Semantic Kernel and all dependencies and the pre-commit config. It uses python 3.10 by default, if you want to change that set the PYTHON_VERSION environment variable to the desired version (currently supported are 3.10, 3.11, 3.12). For instance for 3.12"
make install PYTHON_VERSION=3.12sudo apt-get update && sudo apt-get install python3 python3-pipℹ️ Note: if you don't have your PATH setup to find executables installed by pip3,
<<<<<<< Updated upstream
<<<<<<< div
main ======= <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream ======= origin/main ======= <<<<<<< main Stashed changes ======= <<<<<<< main Stashed changes head ======= <<<<<<< Updated upstream Stashed changes
Check the uv documentation for the installation instructions. At the time of writing this is the command to install uv:
powershell -c "irm https://astral.sh/uv/install.ps1 | iex"
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< main
```python {"id":"01J6KNPX0HTGAZ4YDQ3625T9E4"}
python3 --version ; pip3 --version ; code -v
=======
>>>>>>> ms/features/bugbash-prep
=======
```python {"id":"01J6KNPX0HTGAZ4YDQ3625T9E4"}
python3 --version ; pip3 --version ; code -v
>>>>>>> Stashed changes
=======
```python {"id":"01J6KNPX0HTGAZ4YDQ3625T9E4"}
python3 --version ; pip3 --version ; code -v
>>>>>>> Stashed changesYou can then run the following commands manually:
# Install Python 3.10, 3.11, and 3.12
uv python install 3.10 3.11 3.12
# Create a virtual environment with Python 3.10 (you can change this to 3.11 or 3.12)
$PYTHON_VERSION = "3.10"
uv venv --python $PYTHON_VERSION
# Install SK and all dependencies
uv sync --all-extras --dev
# Install pre-commit hooks
uv run pre-commit install -c python/.pre-commit-config.yamlOr you can then either install make and then follow the guide for Mac and Linux, or run the following commands, the commands are shown as bash but should work in powershell as well.
Stashed changes ======= Stashed changes
It is super simple to get started, run the following commands:
make installThis will install uv, python, Semantic Kernel and all dependencies and the pre-commit config. It uses python 3.10 by default, if you want to change that set the PYTHON_VERSION environment variable to the desired version (currently supported are 3.10, 3.11, 3.12). For instance for 3.12"
make install PYTHON_VERSION=3.12sudo apt-get update && sudo apt-get install python3 python3-pip<<<<<<< Updated upstream <<<<<<< Updated upstream
ms/features/bugbash-prep
It is super simple to get started, run the following commands:
make install=======
Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= ======= Stashed changes ======= Stashed changes origin/main head ======= ======= ======= origin/main Stashed changes Stashed changes
Check the uv documentation for the installation instructions. At the time of writing this is the command to install uv:
powershell -c "irm https://astral.sh/uv/install.ps1 | iex"
<<<<<<< Updated upstream
```python {"id":"01J6KNPX0HTGAZ4YDQ3625T9E4"}
python3 --version ; pip3 --version ; code -v
=======
<<<<<<< main
```python {"id":"01J6KNPX0HTGAZ4YDQ3625T9E4"}
python3 --version ; pip3 --version ; code -v
=======
>>>>>>> ms/features/bugbash-prep
>>>>>>> Stashed changesYou can then run the following commands manually:
# Install Python 3.10, 3.11, and 3.12
uv python install 3.10 3.11 3.12
# Create a virtual environment with Python 3.10 (you can change this to 3.11 or 3.12)
$PYTHON_VERSION = "3.10"
uv venv --python $PYTHON_VERSION
# Install SK and all dependencies
uv sync --all-extras --dev
# Install pre-commit hooks
uv run pre-commit install -c python/.pre-commit-config.yamlOr you can then either install make and then follow the guide for Mac and Linux, or run the following commands, the commands are shown as bash but should work in powershell as well.
<<<<<<< main
Stashed changes
It is super simple to get started, run the following commands:
make install=======
main This will install uv, python, Semantic Kernel and all dependencies and the pre-commit config. It uses python 3.10 by default, if you want to change that set the
PYTHON_VERSIONenvironment variable to the desired version (currently supported are 3.10, 3.11, 3.12). For instance for 3.12"
make install PYTHON_VERSION=3.12<<<<<<< div
sudo apt-get update && sudo apt-get install python3 python3-pipℹ️ Note: if you don't have your PATH setup to find executables installed by pip3,
<<<<<<< Updated upstream
=======
ms/features/bugbash-prep Stashed changes
It is super simple to get started, run the following commands:
make install<<<<<<< main <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream
Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes head ======= <<<<<<< Updated upstream ======= <<<<<<< main Stashed changes Stashed changes To install Poetry in your system, first, navigate to the directory containing this README using your chosen shell. You will need to have Python 3.10, 3.11, or 3.12 installed.
If you want to change python version (without installing uv, python and pre-commit), you can use the same parameter, but do: <<<<<<< Updated upstream <<<<<<< div
<<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream
=======
Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= head ======= <<<<<<< Updated upstream ======= ======= Stashed changes Stashed changes This will install uv, python, Semantic Kernel and all dependencies and the pre-commit config. It uses python 3.10 by default, if you want to change that set the
PYTHON_VERSIONenvironment variable to the desired version (currently supported are 3.10, 3.11, 3.12). For instance for 3.12"
make install PYTHON_VERSION=3.12If you want to change python version (without installing uv, python and pre-commit), you can use the same parameter, but do: <<<<<<< Updated upstream <<<<<<< div
If you want to change python version (without installing uv, python and pre-commit), you can use the same parameter, but do: <<<<<<< main
main
======= <<<<<<< main
origin/main <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= This will install uv, python, Semantic Kernel and all dependencies and the pre-commit config. It uses python 3.10 by default, if you want to change that set the
PYTHON_VERSIONenvironment variable to the desired version (currently supported are 3.10, 3.11, 3.12). For instance for 3.12"
head
make install PYTHON_VERSION=3.12If you want to change python version (without installing uv, python and pre-commit), you can use the same parameter, but do: <<<<<<< main
Stashed changes ======= ======= <<<<<<< Updated upstream ======= <<<<<<< main origin/main Stashed changes Stashed changes
make install-sk PYTHON_VERSION=3.12<<<<<<< main
Stashed changes ======= <<<<<<< main Stashed changes head ======= ======= <<<<<<< main Stashed changes Stashed changes
ℹ️ Note: Running the install or install-sk command will wipe away your existing virtual environment and create a new one.
Alternatively you can run the VSCode task Python: Install to run the same command.
It is best to install Poetry using their
official installer.
On MacOS, you might find that python commands are not recognized by default,
and you can only use python3. To make it easier to run python ... commands
(which Poetry requires), you can create an alias in your shell configuration file.
Open the workspace in VSCode.
The workspace for python should be rooted in the
./pythonfolder.
Open any of the .py files in the project and run the Python: Select Interpreter
command from the command palette. Make sure the virtual env (default path is .venv) created by
uv is selected.
If prompted, install ruff. (It should have been installed as part of uv sync --dev).
You also need to install the ruff extension in VSCode so that auto-formatting uses the ruff formatter on save.
Read more about the extension here.
- Open your shell configuration file:
- For Bash:
nano ~/.bash_profileornano ~/.bashrc - For Zsh (default on macOS Catalina and later):
nano ~/.zshrc
- Add the alias:
alias python='python3'-
Save the file and exit:
- In
nano, pressCTRL + X, thenY, and hitEnter.
- In
-
Apply the changes:
- For Bash:
source ~/.bash_profileorsource ~/.bashrc - For Zsh:
source ~/.zshrc
- For Bash:
After these steps, you should be able to use python in your terminal to run
Python 3 commands.
<<<<<<< Updated upstream
<<<<<<< Updated upstream
origin/main
make install-sk PYTHON_VERSION=3.12<<<<<<< head <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream
=======
Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes <<<<<<< main ======= origin/main ======= ======= Stashed changes
Make sure you have an OpenAI API Key or Azure OpenAI service key
There are two methods to manage keys, secrets, and endpoints:
# Install poetry package if not choosing to install via their official installer
pip3 install poetry
1. Store them in environment variables. SK Python leverages pydantic settings to load keys, secrets, and endpoints from the environment.
> When you are using VSCode and have the python extension setup, it automatically loads environment variables from a `.env` file, so you don't have to manually set them in the terminal.
> During runtime on different platforms, environment settings set as part of the deployments should be used.
2. Store them in a separate `.env` file, like `dev.env`, you can then pass that name into the constructor for most services, to the `env_file_path` parameter, see below.
> Do not store `*.env` files in your repository, and make sure to add them to your `.gitignore` file.
There are a lot of settings, for a more extensive list of settings, see [ALL_SETTINGS.md](./samples/concepts/setup/ALL_SETTINGS.md).
### Example for file-based setup with OpenAI Chat Completions
To configure a `.env` file with just the keys needed for OpenAI Chat Completions, you can create a `openai.env` (this name is just as an example, a single `.env` with all required keys is more common) file in the root of the `python` folder with the following content:
Content of `openai.env`:
```env
OPENAI_API_KEY=""
OPENAI_CHAT_MODEL_ID="gpt-4o-mini"You will then configure the ChatCompletion class with the keyword argument env_file_path:
Open the workspace in VSCode.
The Python workspace is the
./pythonfolder if you are at the root of the repository.
<<<<<<< Updated upstream
Stashed changes ======= Stashed changes
=======
Stashed changes Stashed changes ℹ️ Note: Running the install or install-sk command will wipe away your existing virtual environment and create a new one.
Alternatively you can run the VSCode task Python: Install to run the same command.
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< head
Stashed changes ======= Stashed changes It is best to install Poetry using their official installer.
On MacOS, you might find that python commands are not recognized by default,
and you can only use python3. To make it easier to run python ... commands
(which Poetry requires), you can create an alias in your shell configuration file.
<<<<<<< Updated upstream
<<<<<<< Updated upstream
origin/main ======= Stashed changes ======= Stashed changes
Open the workspace in VSCode.
The workspace for python should be rooted in the
./pythonfolder.
Open any of the .py files in the project and run the Python: Select Interpreter
command from the command palette. Make sure the virtual env (default path is .venv) created by
uv is selected.
If prompted, install ruff. (It should have been installed as part of uv sync --dev).
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< head
Stashed changes
You also need to install the ruff extension in VSCode so that auto-formatting uses the ruff formatter on save.
Read more about the extension here.
- Open your shell configuration file:
head
- For Bash:
nano ~/.bash_profileornano ~/.bashrc - For Zsh (default on macOS Catalina and later):
nano ~/.zshrc
- Add the alias:
alias python='python3'- Save the file and exit:
- In
nano, pressCTRL + X, thenY, and hitEnter.
-
Apply the changes:
- For Bash:
source ~/.bash_profileorsource ~/.bashrc - For Zsh:
source ~/.zshrc
- For Bash:
After these steps, you should be able to use python in your terminal to run
Python 3 commands.
<<<<<<< Updated upstream
=======
Stashed changes Stashed changes
make install-sk PYTHON_VERSION=3.12ℹ️ Note: Running the install or install-sk command will wipe away your existing virtual environment and create a new one.
Alternatively you can run the VSCode task Python: Install to run the same command.
Open the workspace in VSCode.
The workspace for python should be rooted in the
./pythonfolder.
Open any of the .py files in the project and run the Python: Select Interpreter
command from the command palette. Make sure the virtual env (default path is .venv) created by
uv is selected.
If prompted, install ruff. (It should have been installed as part of uv sync --dev).
<<<<<<< Updated upstream
Stashed changes ======= Stashed changes You also need to install the
ruffextension in VSCode so that auto-formatting uses theruffformatter on save. Read more about the extension here.
<<<<<<< Updated upstream
ms/features/bugbash-prep ======= <<<<<<< Updated upstream ======= ms/features/bugbash-prep Stashed changes Stashed changes
Make sure you have an OpenAI API Key or Azure OpenAI service key
<<<<<<< Updated upstream
# Install poetry package if not choosing to install via their official installer
pip3 install poetry
>>>>>>> Stashed changes
```bash {"id":"01J6KNPX0HTGAZ4YDQ3BB96MAY"}
# Install poetry package if not choosing to install via their official installer
pip3 install poetry
=======
<<<<<<< Updated upstream
>>>>>>> ms/features/bugbash-prep
1. Store them in environment variables. SK Python leverages pydantic settings to load keys, secrets, and endpoints from the environment.
> When you are using VSCode and have the python extension setup, it automatically loads environment variables from a `.env` file, so you don't have to manually set them in the terminal.
> During runtime on different platforms, environment settings set as part of the deployments should be used.
2. Store them in a separate `.env` file, like `dev.env`, you can then pass that name into the constructor for most services, to the `env_file_path` parameter, see below.
> Do not store `*.env` files in your repository, and make sure to add them to your `.gitignore` file.
There are a lot of settings, for a more extensive list of settings, see [ALL_SETTINGS.md](./samples/concepts/setup/ALL_SETTINGS.md).
### Example for file-based setup with OpenAI Chat Completions
To configure a `.env` file with just the keys needed for OpenAI Chat Completions, you can create a `openai.env` (this name is just as an example, a single `.env` with all required keys is more common) file in the root of the `python` folder with the following content:
Content of `openai.env`:
```env
OPENAI_API_KEY=""
OPENAI_CHAT_MODEL_ID="gpt-4o-mini"You will then configure the ChatCompletion class with the keyword argument env_file_path:
<<<<<<< main
Open the workspace in VSCode.
The Python workspace is the
./pythonfolder if you are at the root of the repository.
=======
ms/features/bugbash-prep <<<<<<< Updated upstream <<<<<<< Updated upstream
chat_completion = OpenAIChatCompletion(service_id="test", env_file_path="openai.env")origin/main
You also need to install the ruff extension in VSCode so that auto-formatting uses the ruff formatter on save.
Read more about the extension here.
- Open your shell configuration file:
<<<<<<< head
- For Bash:
nano ~/.bash_profileornano ~/.bashrc - For Zsh (default on macOS Catalina and later):
nano ~/.zshrc
- Add the alias:
alias python='python3'
=======
```bash
uv run pytest tests/unit
<<<<<<< main
=======
=======
>>>>>>> Stashed changes
>>>>>>> origin/main
```python
chat_completion = OpenAIChatCompletion(service_id="test", env_file_path="openai.env")You can run the unit tests under the tests/unit folder.
uv run pytest tests/unit
<<<<<<< main
=======
<<<<<<< main
>>>>>>> origin/main
<<<<<<< Updated upstream
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
```bash {"id":"01J6KNPX0HTGAZ4YDQ3CVYSJC6"}
poetry install --with unit-tests
poetry run pytest tests/unit
=======
>>>>>>> ms/features/bugbash-prepAlternatively, you can run them using VSCode Tasks. Open the command palette
(Ctrl+Shift+P) and type Tasks: Run Task. Select Python: Tests - Unit or Python: Tests - Code Coverage from the list.
You can run the integration tests under the tests/integration folder.
uv run pytest tests/integration
<<<<<<< main
<<<<<<< Updated upstream
<<<<<<< Updated upstream
=======
=======
<<<<<<< main
>>>>>>> origin/main
>>>>>>> Stashed changes
=======
=======
<<<<<<< main
>>>>>>> origin/main
>>>>>>> Stashed changes
```bash {"id":"01J6KNPX0HTGAZ4YDQ3ETP16N9"}
poetry install --with tests
poetry run pytest tests/integration
=======
>>>>>>> ms/features/bugbash-prep
<<<<<<< Updated upstream
<<<<<<< Updated upstream
>>>>>>> origin/main- Save the file and exit:
<<<<<<< head
head
- In
nano, pressCTRL + X, thenY, and hitEnter.
-
Apply the changes:
- For Bash:
source ~/.bash_profileorsource ~/.bashrc - For Zsh:
source ~/.zshrc
- For Bash:
After these steps, you should be able to use python in your terminal to run
Python 3 commands.
Make sure you have an OpenAI API Key or Azure OpenAI service key
<<<<<<< main
Stashed changes
# Install poetry package if not choosing to install via their official installer
pip3 install poetry
=======
>>>>>>> ms/features/bugbash-prep
>>>>>>> Stashed changes
1. Store them in environment variables. SK Python leverages pydantic settings to load keys, secrets, and endpoints from the environment.
> When you are using VSCode and have the python extension setup, it automatically loads environment variables from a `.env` file, so you don't have to manually set them in the terminal.
> During runtime on different platforms, environment settings set as part of the deployments should be used.
2. Store them in a separate `.env` file, like `dev.env`, you can then pass that name into the constructor for most services, to the `env_file_path` parameter, see below.
> Do not store `*.env` files in your repository, and make sure to add them to your `.gitignore` file.
There are a lot of settings, for a more extensive list of settings, see [ALL_SETTINGS.md](./samples/concepts/setup/ALL_SETTINGS.md).
### Example for file-based setup with OpenAI Chat Completions
To configure a `.env` file with just the keys needed for OpenAI Chat Completions, you can create a `openai.env` (this name is just as an example, a single `.env` with all required keys is more common) file in the root of the `python` folder with the following content:
Content of `openai.env`:
```env
OPENAI_API_KEY=""
OPENAI_CHAT_MODEL_ID="gpt-4o-mini"You will then configure the ChatCompletion class with the keyword argument env_file_path:
<<<<<<< Updated upstream
<<<<<<< main
Stashed changes
Open the workspace in VSCode.
The Python workspace is the
./pythonfolder if you are at the root of the repository.
<<<<<<< Updated upstream ℹ️ Note: Running the install or install-sk command will wipe away your existing virtual environment and create a new one.
Alternatively you can run the VSCode task Python: Install to run the same command.
It is best to install Poetry using their
official installer.
On MacOS, you might find that python commands are not recognized by default,
and you can only use python3. To make it easier to run python ... commands
(which Poetry requires), you can create an alias in your shell configuration file.
Open the workspace in VSCode.
The workspace for python should be rooted in the
./pythonfolder.
Open any of the .py files in the project and run the Python: Select Interpreter
command from the command palette. Make sure the virtual env (default path is .venv) created by
uv is selected.
If prompted, install ruff. (It should have been installed as part of uv sync --dev).
You also need to install the ruff extension in VSCode so that auto-formatting uses the ruff formatter on save.
Read more about the extension here.
-
Open your shell configuration file:
- For Bash:
nano ~/.bash_profileornano ~/.bashrc - For Zsh (default on macOS Catalina and later):
nano ~/.zshrc
- For Bash:
-
Add the alias:
=======
ℹ️ Note: Running the install or install-sk command will wipe away your existing virtual environment and create a new one.
Alternatively you can run the VSCode task Python: Install to run the same command.
It is best to install Poetry using their
official installer.
On MacOS, you might find that python commands are not recognized by default,
and you can only use python3. To make it easier to run python ... commands
(which Poetry requires), you can create an alias in your shell configuration file.
Open the workspace in VSCode.
The workspace for python should be rooted in the
./pythonfolder.
Open any of the .py files in the project and run the Python: Select Interpreter
command from the command palette. Make sure the virtual env (default path is .venv) created by
uv is selected.
If prompted, install ruff. (It should have been installed as part of uv sync --dev).
You also need to install the ruff extension in VSCode so that auto-formatting uses the ruff formatter on save.
Read more about the extension here.
-
Open your shell configuration file:
- For Bash:
nano ~/.bash_profileornano ~/.bashrc - For Zsh (default on macOS Catalina and later):
nano ~/.zshrc
- For Bash:
-
Add the alias:
main
alias python='python3'-
Save the file and exit:
- In
nano, pressCTRL + X, thenY, and hitEnter.
- In
-
Apply the changes:
- For Bash:
source ~/.bash_profileorsource ~/.bashrc - For Zsh:
source ~/.zshrc
- For Bash:
After these steps, you should be able to use python in your terminal to run
Python 3 commands.
<<<<<<< div
=======
main
make install-sk PYTHON_VERSION=3.12ℹ️ Note: Running the install or install-sk command will wipe away your existing virtual environment and create a new one.
Alternatively you can run the VSCode task Python: Install to run the same command.
Open the workspace in VSCode.
The workspace for python should be rooted in the
./pythonfolder.
Open any of the .py files in the project and run the Python: Select Interpreter
command from the command palette. Make sure the virtual env (default path is .venv) created by
uv is selected.
If prompted, install ruff. (It should have been installed as part of uv sync --dev).
You also need to install the ruff extension in VSCode so that auto-formatting uses the ruff formatter on save.
Read more about the extension here.
ms/features/bugbash-prep main
Make sure you have an OpenAI API Key or Azure OpenAI service key
There are two methods to manage keys, secrets, and endpoints: <<<<<<< div
# Install poetry package if not choosing to install via their official installer
pip3 install poetry
```bash {"id":"01J6KNPX0HTGAZ4YDQ3BB96MAY"}
# Install poetry package if not choosing to install via their official installer
pip3 install poetry
=======
<<<<<<< main
```bash {"id":"01J6KNPX0HTGAZ4YDQ3BB96MAY"}
# Install poetry package if not choosing to install via their official installer
pip3 install poetry
=======
>>>>>>> ms/features/bugbash-prep
>>>>>>> main
1. Store them in environment variables. SK Python leverages pydantic settings to load keys, secrets, and endpoints from the environment.
> When you are using VSCode and have the python extension setup, it automatically loads environment variables from a `.env` file, so you don't have to manually set them in the terminal.
> During runtime on different platforms, environment settings set as part of the deployments should be used.
2. Store them in a separate `.env` file, like `dev.env`, you can then pass that name into the constructor for most services, to the `env_file_path` parameter, see below.
> Do not store `*.env` files in your repository, and make sure to add them to your `.gitignore` file.
There are a lot of settings, for a more extensive list of settings, see [ALL_SETTINGS.md](./samples/concepts/setup/ALL_SETTINGS.md).
### Example for file-based setup with OpenAI Chat Completions
To configure a `.env` file with just the keys needed for OpenAI Chat Completions, you can create a `openai.env` (this name is just as an example, a single `.env` with all required keys is more common) file in the root of the `python` folder with the following content:
Content of `openai.env`:
```env
OPENAI_API_KEY=""
OPENAI_CHAT_MODEL_ID="gpt-4o-mini"You will then configure the ChatCompletion class with the keyword argument env_file_path:
<<<<<<< div
<<<<<<< main
main
Open the workspace in VSCode.
The Python workspace is the
./pythonfolder if you are at the root of the repository.
<<<<<<< div
======= <<<<<<< Updated upstream
Stashed changes ======= =======
ms/features/bugbash-prep <<<<<<< Updated upstream main ======= origin/main Stashed changes Stashed changes
chat_completion = OpenAIChatCompletion(service_id="test", env_file_path="openai.env")You can run the unit tests under the tests/unit folder.
uv run pytest tests/unit
<<<<<<< Updated upstream
<<<<<<< div
=======
<<<<<<< Updated upstream
```bash {"id":"01J6KNPX0HTGAZ4YDQ3CVYSJC6"}
poetry install --with unit-tests
poetry run pytest tests/unit
>>>>>>> Stashed changes
```bash {"id":"01J6KNPX0HTGAZ4YDQ3CVYSJC6"}
poetry install --with unit-tests
poetry run pytest tests/unit
=======
<<<<<<< main
<<<<<<< Updated upstream
>>>>>>> main
=======
=======
<<<<<<< main
>>>>>>> origin/main
>>>>>>> Stashed changes
```bash {"id":"01J6KNPX0HTGAZ4YDQ3CVYSJC6"}
poetry install --with unit-tests
poetry run pytest tests/unit
=======
>>>>>>> ms/features/bugbash-prep
<<<<<<< Updated upstream
=======
>>>>>>> Stashed changes
>>>>>>> Stashed changesAlternatively, you can run them using VSCode Tasks. Open the command palette
(Ctrl+Shift+P) and type Tasks: Run Task. Select Python: Tests - Unit or Python: Tests - Code Coverage from the list.
You can run the integration tests under the tests/integration folder.
uv run pytest tests/integration
<<<<<<< Updated upstream
<<<<<<< div
=======
<<<<<<< Updated upstream
```bash {"id":"01J6KNPX0HTGAZ4YDQ3ETP16N9"}
poetry install --with tests
poetry run pytest tests/integration
>>>>>>> Stashed changes
```bash {"id":"01J6KNPX0HTGAZ4YDQ3ETP16N9"}
poetry install --with tests
poetry run pytest tests/integration
=======
<<<<<<< main
<<<<<<< Updated upstream
>>>>>>> main
=======
=======
<<<<<<< main
>>>>>>> origin/main
>>>>>>> Stashed changes
```bash {"id":"01J6KNPX0HTGAZ4YDQ3ETP16N9"}
poetry install --with tests
poetry run pytest tests/integration
=======
>>>>>>> ms/features/bugbash-prep
<<<<<<< Updated upstreamYou can also run all the tests together under the tests folder.
uv run pytest tests
<<<<<<< div
```bash {"id":"01J6KNPX0HTGAZ4YDQ3GYN6VJR"}
poetry install
poetry run pytest tests
=======
<<<<<<< main
>>>>>>> main
```bash {"id":"01J6KNPX0HTGAZ4YDQ3GYN6VJR"}
poetry install
poetry run pytest tests
=======
>>>>>>> ms/features/bugbash-prep
<<<<<<< div
=======
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changesAlternatively, you can run them using VSCode Tasks. Open the command palette
(Ctrl+Shift+P) and type Tasks: Run Task. Select Python: Tests - All from the list.
Stashed changes Stashed changes
You can also run all the tests together under the [tests](tests/) folder.
```bash
uv run pytest tests
<<<<<<< Updated upstream
<<<<<<< main
=======
<<<<<<< main
>>>>>>> origin/main
=======
<<<<<<< Updated upstream
```bash {"id":"01J6KNPX0HTGAZ4YDQ3GYN6VJR"}
poetry install
poetry run pytest tests
>>>>>>> Stashed changes
```bash {"id":"01J6KNPX0HTGAZ4YDQ3GYN6VJR"}
poetry install
poetry run pytest tests
=======
<<<<<<< Updated upstream
>>>>>>> ms/features/bugbash-prep
Alternatively, you can run them using VSCode Tasks. Open the command palette
(Ctrl+Shift+P) and type Tasks: Run Task. Select Python: Tests - All from the list.
Stashed changes
It's important to note that most of this library is written with asynchronous in mind. The
developer should always assume everything is asynchronous. One can use the function signature
with either async def or def to understand if something is asynchronous or not.
Each file should have a single first line containing: # Copyright (c) Microsoft. All rights reserved.
We follow the Google Docstring style guide for functions and methods. They are currently not checked for private functions (functions starting with '_').
They should contain:
- Single line explaining what the function does, ending with a period.
- If necessary to further explain the logic a newline follows the first line and then the explanation is given.
- The following three sections are optional, and if used should be separated by a single empty line.
- Arguments are then specified after a header called
Args:, with each argument being specified in the following format:arg_name: Explanation of the argument.- if a longer explanation is needed for a argument, it should be placed on the next line, indented by 4 spaces.
- Type and default values do not have to be specified, they will be pulled from the definition. <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream ======= =======
Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes <<<<<<< main ======= <<<<<<< main origin/main <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes =======
You can also run all the tests together under the [tests](tests/) folder.
```bash
uv run pytest tests
=======
>>>>>>> Stashed changes
<<<<<<< main
=======
<<<<<<< main
>>>>>>> origin/main
```bash {"id":"01J6KNPX0HTGAZ4YDQ3GYN6VJR"}
poetry install
poetry run pytest tests
=======
>>>>>>> ms/features/bugbash-prep
<<<<<<< Updated upstream
>>>>>>> head
=======
>>>>>>> Stashed changes
>>>>>>> Stashed changes
Alternatively, you can run them using VSCode Tasks. Open the command palette
(Ctrl+Shift+P) and type Tasks: Run Task. Select Python: Tests - All from the list.
It's important to note that most of this library is written with asynchronous in mind. The
developer should always assume everything is asynchronous. One can use the function signature
with either async def or def to understand if something is asynchronous or not.
Each file should have a single first line containing: # Copyright (c) Microsoft. All rights reserved.
We follow the Google Docstring style guide for functions and methods. They are currently not checked for private functions (functions starting with '_').
They should contain:
- Single line explaining what the function does, ending with a period.
- If necessary to further explain the logic a newline follows the first line and then the explanation is given.
- The following three sections are optional, and if used should be separated by a single empty line.
- Arguments are then specified after a header called
Args:, with each argument being specified in the following format:arg_name: Explanation of the argument.- if a longer explanation is needed for a argument, it should be placed on the next line, indented by 4 spaces.
- Type and default values do not have to be specified, they will be pulled from the definition. <<<<<<< Updated upstream <<<<<<< div <<<<<<< div ======= <<<<<<< main
main ======= <<<<<<< Updated upstream Stashed changes ======= <<<<<<< main ======= <<<<<<< main origin/main Stashed changes <<<<<<< Updated upstream head ======= Stashed changes
arg_name(arg_type): Explanation of the argument, arg_type is optional, as long as you are consistent.- if a longer explanation is needed for a argument, it should be placed on the next line, indented by 4 spaces.
- Default values do not have to be specified, they will be pulled from the definition.
=======
ms/features/bugbash-prep main ======= <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream ======= ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= <<<<<<< Updated upstream ======= Stashed changes <<<<<<< main ======= ======= ms/features/bugbash-prep origin/main <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes head ======= Stashed changes Stashed changes
- Returns are specified after a header called
Returns:orYields:, with the return type and explanation of the return value. - Finally, a header for exceptions can be added, called
Raises:, with each exception being specified in the following format:ExceptionType: Explanation of the exception.- if a longer explanation is needed for a exception, it should be placed on the next line, indented by 4 spaces.
Putting them all together, gives you at minimum this:
def equal(arg1: str, arg2: str) -> bool:
"""Compares two strings and returns True if they are the same."""
...<<<<<<< div
<<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream
=======
Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes <<<<<<< main head ======= <<<<<<< Updated upstream ======= <<<<<<< main Stashed changes Stashed changes
def equal(arg1: str, arg2: str) -> bool:
"""Compares two strings and returns True if they are the same.
<<<<<<< Updated upstream
<<<<<<< div
=======
<<<<<<< Updated upstream
>>>>>>> Stashed changes
```python {"id":"01J6KNPX0HTGAZ4YDQ3JGT3D67"}
def equal(arg1: str, arg2: str) -> bool:
"""Compares two strings and returns True if they are the same.
Here is extra explanation of the logic involved.
Args:
arg1: The first string to compare.
arg2: The second string to compare.
This string requires extra explanation.
Returns:
True if the strings are the same, False otherwise.
Raises:
ValueError: If one of the strings is empty.
"""
...If in doubt, use the link above to read much more considerations of what to do and when, or use common sense.
This section describes how one can enable serialization for their class using Pydantic. For more info you can refer to the Pydantic Documentation.
uv run pytest tests
```bash {"id":"01J6KNPX0HTGAZ4YDQ3GYN6VJR"}
poetry install
poetry run pytest testsAlternatively, you can run them using VSCode Tasks. Open the command palette
(Ctrl+Shift+P) and type Tasks: Run Task. Select Python: Tests - All from the list.
It's important to note that most of this library is written with asynchronous programming in mind. The
developer should always assume everything is asynchronous. One can use the function signature
with either async def or def to understand if something is asynchronous or not.
Each file should have a single first line containing: # Copyright (c) Microsoft. All rights reserved.
We follow the Google Docstring style guide for functions and methods. They are currently not checked for private functions (functions starting with '_').
They should contain:
-
Single line explaining what the function does, ending with a period.
-
If necessary to further explain the logic a newline follows the first line and then the explanation is given.
-
The following three sections are optional, and if used should be separated by a single empty line.
-
Arguments are then specified after a header called
Args:, with each argument being specified in the following format:arg_name: Explanation of the argument.- if a longer explanation is needed for a argument, it should be placed on the next line, indented by 4 spaces.
- Type and default values do not have to be specified, they will be pulled from the definition.
arg_name(arg_type): Explanation of the argument, arg_type is optional, as long as you are consistent.- if a longer explanation is needed for a argument, it should be placed on the next line, indented by 4 spaces.
- Default values do not have to be specified, they will be pulled from the definition.
-
Returns are specified after a header called
Returns:orYields:, with the return type and explanation of the return value. -
Finally, a header for exceptions can be added, called
Raises:, with each exception being specified in the following format:ExceptionType: Explanation of the exception.- if a longer explanation is needed for a exception, it should be placed on the next line, indented by 4 spaces.
Putting them all together, gives you at minimum this:
def equal(arg1: str, arg2: str) -> bool:
"""Compares two strings and returns True if they are the same."""
...======= <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream <<<<<<< Updated upstream
Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes ======= Stashed changes head ======= Stashed changes Stashed changes
def equal(arg1: str, arg2: str) -> bool:
"""Compares two strings and returns True if they are the same.
<<<<<<< Updated upstream
<<<<<<< div
=======
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
=======
>>>>>>> origin/main
>>>>>>> Stashed changes
=======
>>>>>>> origin/main
>>>>>>> Stashed changes
=======
>>>>>>> origin/main
>>>>>>> Stashed changes
=======
>>>>>>> origin/main
>>>>>>> Stashed changes
=======
>>>>>>> origin/main
>>>>>>> Stashed changes
>>>>>>> head
=======
<<<<<<< Updated upstream
=======
>>>>>>> origin/main
>>>>>>> Stashed changes
>>>>>>> Stashed changes
Here is extra explanation of the logic involved.
Args:
arg1: The first string to compare.
arg2: The second string to compare.
This string requires extra explanation.
Returns:
True if the strings are the same, False otherwise.
Raises:
ValueError: If one of the strings is empty.
"""
...If in doubt, use the link above to read much more considerations of what to do and when, or use common sense.
This section describes how one can enable serialization for their class using Pydantic. For more info you can refer to the Pydantic Documentation.
=======
uv run pytest tests
<<<<<<< main
```bash {"id":"01J6KNPX0HTGAZ4YDQ3GYN6VJR"}
poetry install
poetry run pytest tests
=======
>>>>>>> ms/features/bugbash-prepAlternatively, you can run them using VSCode Tasks. Open the command palette
(Ctrl+Shift+P) and type Tasks: Run Task. Select Python: Tests - All from the list.
It's important to note that most of this library is written with asynchronous programming in mind. The
developer should always assume everything is asynchronous. One can use the function signature
with either async def or def to understand if something is asynchronous or not.
Each file should have a single first line containing: # Copyright (c) Microsoft. All rights reserved.
We follow the Google Docstring style guide for functions and methods. They are currently not checked for private functions (functions starting with '_').
They should contain:
- Single line explaining what the function does, ending with a period.
- If necessary to further explain the logic a newline follows the first line and then the explanation is given.
- The following three sections are optional, and if used should be separated by a single empty line.
- Arguments are then specified after a header called
Args:, with each argument being specified in the following format:arg_name: Explanation of the argument.- if a longer explanation is needed for a argument, it should be placed on the next line, indented by 4 spaces.
- Type and default values do not have to be specified, they will be pulled from the definition. <<<<<<< main
arg_name(arg_type): Explanation of the argument, arg_type is optional, as long as you are consistent.- if a longer explanation is needed for a argument, it should be placed on the next line, indented by 4 spaces.
- Default values do not have to be specified, they will be pulled from the definition.
=======
ms/features/bugbash-prep
- Returns are specified after a header called
Returns:orYields:, with the return type and explanation of the return value. - Finally, a header for exceptions can be added, called
Raises:, with each exception being specified in the following format:ExceptionType: Explanation of the exception.- if a longer explanation is needed for a exception, it should be placed on the next line, indented by 4 spaces.
Putting them all together, gives you at minimum this:
def equal(arg1: str, arg2: str) -> bool:
"""Compares two strings and returns True if they are the same."""
...Stashed changes
def equal(arg1: str, arg2: str) -> bool:
"""Compares two strings and returns True if they are the same.
<<<<<<< Updated upstream
=======
>>>>>>> origin/main
>>>>>>> Stashed changes
>>>>>>> head
=======
Or a complete version of this:
```python {"id":"01J6KNPX0HTGAZ4YDQ3JGT3D67"}
def equal(arg1: str, arg2: str) -> bool:
"""Compares two strings and returns True if they are the same.
Here is extra explanation of the logic involved.
Args:
arg1: The first string to compare.
arg2: The second string to compare.
This string requires extra explanation.
Returns:
True if the strings are the same, False otherwise.
Raises:
ValueError: If one of the strings is empty.
"""
...If in doubt, use the link above to read much more considerations of what to do and when, or use common sense.
main This section describes how one can enable serialization for their class using Pydantic. For more info you can refer to the Pydantic Documentation.
<<<<<<< Updated upstream <<<<<<< Updated upstream
origin/main ======= Stashed changes ======= Stashed changes head
Let's take the following example:
class A:
def __init__(self, a: int, b: float, c: List[float], d: dict[str, tuple[float, str]] = {}):
self.a = a
self.b = b
self.c = c
self.d = dYou would convert this to a Pydantic class by sub-classing from the KernelBaseModel class.
from pydantic import Field
from semantic_kernel.kernel_pydantic import KernelBaseModel
class A(KernelBaseModel):
# The notation for the fields is similar to dataclasses.
a: int
b: float
c: list[float]
# Only, instead of using dataclasses.field, you would use pydantic.Field
d: dict[str, tuple[float, str]] = Field(default_factory=dict)Let's take the following example:
from typing import TypeVar
T1 = TypeVar("T1")
T2 = TypeVar("T2", bound=<some class>)
class A:
def __init__(a: int, b: T1, c: T2):
self.a = a
self.b = b
self.c = cYou can use the KernelBaseModel to convert these to pydantic serializable classes.
from typing import Generic, TypeVar
<<<<<<< Updated upstream
<<<<<<< div
<<<<<<< div
=======
<<<<<<< main
>>>>>>> main
=======
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< head
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
=======
<<<<<<< main
>>>>>>> origin/main
>>>>>>> head
=======
<<<<<<< Updated upstream
>>>>>>> Stashed changes
```python {"id":"01J6KNPX0HTGAZ4YDQ3R7VE7KV"}
from typing import Generic
=======
>>>>>>> ms/features/bugbash-prep
from semantic_kernel.kernel_pydantic import KernelBaseModel
<<<<<<< div
<<<<<<< div
=======
<<<<<<< head
=======
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
<<<<<<< main
=======
<<<<<<< main
>>>>>>> origin/main
>>>>>>> head
```python {"id":"01J6KNPX0HTGAZ4YDQ3R7VE7KV"}
from typing import Generic
from semantic_kernel.kernel_pydantic import KernelBaseModel
<<<<<<< Updated upstream
<<<<<<< div
=======
<<<<<<< main
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
>>>>>>> head
=======
=======
<<<<<<< main
=======
<<<<<<< main
>>>>>>> origin/main
```python {"id":"01J6KNPX0HTGAZ4YDQ3R7VE7KV"}
from typing import Generic
=======
>>>>>>> ms/features/bugbash-prep
from semantic_kernel.kernel_pydantic import KernelBaseModel
<<<<<<< main
>>>>>>> Stashed changes
>>>>>>> Stashed changes
T1 = TypeVar("T1")
T2 = TypeVar("T2", bound=<some class>)
<<<<<<< Updated upstream
<<<<<<< div
=======
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
=======
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
>>>>>>> head
=======
=======
>>>>>>> Stashed changes
>>>>>>> main
T1 = TypeVar("T1")
T2 = TypeVar("T2", bound=<some class>)
<<<<<<< div
=======
<<<<<<< Updated upstream
>>>>>>> origin/main
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
T1 = TypeVar("T1")
T2 = TypeVar("T2", bound=<some class>)
>>>>>>> origin/main
>>>>>>> head
=======
<<<<<<< Updated upstream
T1 = TypeVar("T1")
T2 = TypeVar("T2", bound=<some class>)
=======
=======
T1 = TypeVar("T1")
T2 = TypeVar("T2", bound=<some class>)
>>>>>>> origin/main
>>>>>>> Stashed changes
>>>>>>> Stashed changes
class A(KernelBaseModel, Generic[T1, T2]):
# T1 and T2 must be specified in the Generic argument otherwise, pydantic will
# NOT be able to serialize this class
a: int
b: T1
c: T2To run the same checks that run during a commit and the GitHub Action Python Code Quality Checks, you can use this command, from the python folder:
uv run pre-commit run -a
<<<<<<< Updated upstream
<<<<<<< div
<<<<<<< div
```bash {"id":"01J6KNPX0HTGAZ4YDQ3RB8FHQJ"}
poetry run pre-commit run -a
=======
<<<<<<< Updated upstream
>>>>>>> Stashed changes
```bash {"id":"01J6KNPX0HTGAZ4YDQ3RB8FHQJ"}
poetry run pre-commit run -a
```bash {"id":"01J6KNPX0HTGAZ4YDQ3RB8FHQJ"}
poetry run pre-commit run -a
=======
=======
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< head
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
```bash {"id":"01J6KNPX0HTGAZ4YDQ3RB8FHQJ"}
poetry run pre-commit run -a
=======
<<<<<<< Updated upstream
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
<<<<<<< main
```bash {"id":"01J6KNPX0HTGAZ4YDQ3RB8FHQJ"}
poetry run pre-commit run -a
=======
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
=======
>>>>>>> origin/main
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
>>>>>>> head
=======
>>>>>>> Stashed changes
<<<<<<< main
```bash {"id":"01J6KNPX0HTGAZ4YDQ3RB8FHQJ"}
poetry run pre-commit run -a
=======
>>>>>>> ms/features/bugbash-prep
<<<<<<< Updated upstream
<<<<<<< div
>>>>>>> main
=======
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< head
>>>>>>> origin/main
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
>>>>>>> origin/main
>>>>>>> head
=======
>>>>>>> origin/main
>>>>>>> Stashed changes
>>>>>>> Stashed changesor use the following task (using Ctrl+Shift+P):
Python - Run Checksto run the checks on the whole project.Python - Run Checks - Stagedto run the checks on the currently staged files only.
Ideally you should run these checks before committing any changes, when you install using the instructions above the pre-commit hooks should be installed already.
We try to maintain a high code coverage for the project. To run the code coverage on the unit tests, you can use the following command:
uv run pytest --cov=semantic_kernel --cov-report=term-missing:skip-covered tests/unit/
<<<<<<< Updated upstream
<<<<<<< div
<<<<<<< div
```bash {"id":"01J6KNPX0HTGAZ4YDQ3V7S5W7V"}
poetry run pytest --cov=semantic_kernel --cov-report=term-missing:skip-covered tests/unit/
=======
<<<<<<< Updated upstream
>>>>>>> Stashed changes
```bash {"id":"01J6KNPX0HTGAZ4YDQ3V7S5W7V"}
poetry run pytest --cov=semantic_kernel --cov-report=term-missing:skip-covered tests/unit/
```bash {"id":"01J6KNPX0HTGAZ4YDQ3V7S5W7V"}
poetry run pytest --cov=semantic_kernel --cov-report=term-missing:skip-covered tests/unit/
<<<<<<< Updated upstream
=======
=======
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< head
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
```bash {"id":"01J6KNPX0HTGAZ4YDQ3V7S5W7V"}
poetry run pytest --cov=semantic_kernel --cov-report=term-missing:skip-covered tests/unit/
=======
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
```bash {"id":"01J6KNPX0HTGAZ4YDQ3V7S5W7V"}
poetry run pytest --cov=semantic_kernel --cov-report=term-missing:skip-covered tests/unit/
=======
>>>>>>> Stashed changes
<<<<<<< main
```bash {"id":"01J6KNPX0HTGAZ4YDQ3V7S5W7V"}
poetry run pytest --cov=semantic_kernel --cov-report=term-missing:skip-covered tests/unit/
=======
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
=======
>>>>>>> origin/main
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
>>>>>>> head
=======
>>>>>>> Stashed changes
<<<<<<< main
```bash {"id":"01J6KNPX0HTGAZ4YDQ3V7S5W7V"}
poetry run pytest --cov=semantic_kernel --cov-report=term-missing:skip-covered tests/unit/
=======
>>>>>>> ms/features/bugbash-prep
<<<<<<< Updated upstream
<<<<<<< div
>>>>>>> main
=======
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< head
>>>>>>> origin/main
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< Updated upstream
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
=======
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
>>>>>>> origin/main
>>>>>>> head
=======
>>>>>>> origin/main
>>>>>>> Stashed changes
>>>>>>> Stashed changesor use the following task (using Ctrl+Shift+P):
Python: Tests - Code Coverageto run the code coverage on the whole project.
This will show you which files are not covered by the tests, including the specific lines not covered. Make sure to consider the untested lines from the code you are working on, but feel free to add other tests as well, that is always welcome!
There are many people committing to Semantic Kernel, so it is important to keep your local repository up to date. To do this, you can run the following commands:
git fetch upstream main
git rebase upstream/main
git push --force-with-leaseor:
git fetch upstream main
git merge upstream/main
git push
<<<<<<< div
<<<<<<< div
=======
<<<<<<< Updated upstream
<<<<<<< Updated upstream
<<<<<<< head
=======
>>>>>>> Stashed changes
>>>>>>> headThis is assuming the upstream branch refers to the main repository. If you have a different name for the upstream branch, you can replace upstream with the name of your upstream branch.
After running the rebase command, you may need to resolve any conflicts that arise. If you are unsure how to resolve a conflict, please refer to the GitHub's documentation on resolving conflicts, or for VSCode.
Make sure you have an Open AI API Key or Azure Open AI service key
ℹ️ Note: Azure OpenAI support is work in progress, and will be available soon.
Copy those keys into a .env file like this:
OPENAI_API_KEY=""
OPENAI_ORG_ID=""
AZURE_OPENAI_API_KEY=""
AZURE_OPENAI_ENDPOINT=""
=======
Stashed changes head
This is assuming the upstream branch refers to the main repository. If you have a different name for the upstream branch, you can replace `upstream` with the name of your upstream branch.
After running the rebase command, you may need to resolve any conflicts that arise. If you are unsure how to resolve a conflict, please refer to the [GitHub's documentation on resolving conflicts](https://docs.github.com/en/get-started/using-git/resolving-merge-conflicts-after-a-git-rebase), or for [VSCode](https://code.visualstudio.com/docs/sourcecontrol/overview#_merge-conflicts).
# LLM setup
Make sure you have an
[Open AI API Key](https://openai.com/api/) or
[Azure Open AI service key](https://learn.microsoft.com/azure/cognitive-services/openai/quickstart?pivots=rest-api)
ℹ️ **Note**: Azure OpenAI support is work in progress, and will be available soon.
Copy those keys into a `.env` file like this:
OPENAI_API_KEY="" OPENAI_ORG_ID="" AZURE_OPENAI_API_KEY="" AZURE_OPENAI_ENDPOINT=""
<<<<<<< div
>>>>>>> main
=======
<<<<<<< Updated upstream
>>>>>>> origin/main
=======
>>>>>>> Stashed changes
=======
>>>>>>> Stashed changes
>>>>>>> head
We suggest adding a copy of the `.env` file under these folders:
- [python/tests](tests)
- [samples/notebooks/python](../samples/notebooks/python).
# Quickstart with Poetry
Poetry allows to use SK from the current repo, without worrying about paths, as
if you had SK pip package installed. SK pip package will be published after
porting all the major features and ensuring cross-compatibility with C# SDK.
To install Poetry in your system:
pip3 install poetry
The following command install the project dependencies:
poetry install
And the following activates the project virtual environment, to make it easier
running samples in the repo and developing apps using Python SK.
poetry shell
To run the same checks that are run during the Azure Pipelines build, you can run:
poetry run pre-commit run -c .conf/.pre-commit-config.yaml -a
# VSCode Setup
Open any of the `.py` files in the project and run the `Python: Select Interpreter` command
from the command palette. Make sure the virtual env (venv) created by `poetry` is selected.
The python you're looking for should be under `~/.cache/pypoetry/virtualenvs/semantic-kernel-.../bin/python`.
If prompted, install `black` and `flake8` (if VSCode doesn't find those packages,
it will prompt you to install them).
# Tests
You should be able to run the example under the [tests](tests) folder.