-
Notifications
You must be signed in to change notification settings - Fork 235
/
Makefile
159 lines (131 loc) · 6.14 KB
/
Makefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
.PHONY: clean test lint init check-readme docs
TEST_PATH=./
INTEGRATION_TEST_FOLDER = integration_tests
GRPC_SERVER_INTEGRATION_TEST_FOLDER = $(INTEGRATION_TEST_FOLDER)/grpc_server
help: ## show help message
@grep -hE '^[A-Za-z0-9_ \-]*?:.*##.*$$' $(MAKEFILE_LIST) | sort | awk 'BEGIN {FS = ":.*?## "}; {printf "\033[36m%-30s\033[0m %s\n", $$1, $$2}'
install: ## install dependencies
poetry run python -m pip install -U pip
poetry install
install-dev: ## install dependencies for development
poetry run python -m pip install -U pip
poetry install --with dev
clean: ## remove all build, test, coverage and Python artifacts
find . -name '*.pyc' -exec rm -f {} +
find . -name '*.pyo' -exec rm -f {} +
find . -name '*~' -exec rm -f {} +
rm -rf build/
rm -rf dist/
rm -rf *.egg-info
types: ## check types
poetry run mypy rasa_sdk
formatter: ## format code
poetry run ruff format rasa_sdk tests
lint: ## check style with ruff and black
poetry run ruff check rasa_sdk tests --ignore D
poetry run ruff format --check rasa_sdk tests
make lint-docstrings
make check-generate-grpc-code-in-sync
# Compare against `main` if no branch was provided
BRANCH ?= main
lint-docstrings: ## check docstrings
./scripts/lint_python_docstrings.sh $(BRANCH)
IMAGE_NAME ?= rasa/rasa-sdk
IMAGE_WITH_DEV_DEPS ?= rasa/rasa-sdk-with-dev-deps
IMAGE_TAG ?= latest
PLATFORM ?= linux/arm64
POETRY_VERSION ?= $(shell ./scripts/poetry-version.sh)
# Builds a docker image with runtime dependencies installed
build-docker: ## build docker image for one platform
docker build . \
--build-arg POETRY_VERSION=$(POETRY_VERSION) \
--platform=$(PLATFORM) \
-f Dockerfile \
-t $(IMAGE_NAME):$(IMAGE_TAG)
# Builds a docker image with runtime and dev dependencies installed
build-docker-with-dev-deps: ## build docker image with dev dependencies for one platform
docker build . \
--build-arg POETRY_VERSION=$(POETRY_VERSION) \
--platform=$(PLATFORM) \
-f Dockerfile.dev \
-t $(IMAGE_WITH_DEV_DEPS):$(IMAGE_TAG)
# To be able to build a multiplatform docker image
# make sure that builder with appropriate docker driver is enabled and set as current builder
build-and-push-multi-platform-docker: PLATFORM = linux/amd64,linux/arm64
build-and-push-multi-platform-docker: ## build and push multi-platform docker image
docker buildx build . \
--build-arg POETRY_VERSION=$(POETRY_VERSION) \
--platform=$(PLATFORM) \
-f Dockerfile \
-t $(IMAGE_NAME):$(IMAGE_TAG) \
-t $(IMAGE_NAME):$(IMAGE_TAG)-latest \
--push
# To be able to build a multiplatform docker image with dev dependencies
# make sure that builder with appropriate docker driver is enabled and set as current builder
build-and-push-multi-platform-docker-with-dev-deps: PLATFORM = linux/amd64,linux/arm64
build-and-push-multi-platform-docker-with-dev-deps: ## build and push multi-platform docker image with dev dependencies
docker buildx build . \
--build-arg POETRY_VERSION=$(POETRY_VERSION) \
--platform=$(PLATFORM) \
-f Dockerfile.dev \
-t $(IMAGE_WITH_DEV_DEPS):$(IMAGE_TAG) \
--push
test: clean ## run tests
poetry run \
pytest tests \
--cov rasa_sdk \
-v
generate-pending-changelog: ## generate a changelog for the next release
poetry run python -c "from scripts import release; release.generate_changelog('major.minor.patch')"
cleanup-generated-changelog: ## cleanup the generated changelog
# this is a helper to cleanup your git status locally after running "make test-docs"
# it's not run on CI at the moment
git status --porcelain | sed -n '/^D */s///p' | xargs git reset HEAD
git reset HEAD CHANGELOG.mdx
git ls-files --deleted | xargs git checkout
git checkout CHANGELOG.mdx
release: ## start the release process
poetry run python scripts/release.py
tag-release: ## Tag a release.
poetry run python scripts/release.py --tag
generate-grpc: ## generate grpc code
poetry run python -m grpc_tools.protoc \
-Irasa_sdk/grpc_py=./proto \
--python_out=. \
--grpc_python_out=. \
--pyi_out=. \
proto/action_webhook.proto
check-generate-grpc-code-in-sync: generate-grpc ## check if the generated code is in sync with the proto files, it uses a helper to check if the generated code is in sync with the proto files
git diff --exit-code rasa_sdk/grpc_py | if [ "$$(wc -c)" -eq 0 ]; then echo "Generated code is in sync with proto files"; else echo "Generated code is not in sync with proto files"; exit 1; fi
GRPC_STANDALONE_SERVER_INTEGRATION_TEST_RESULTS_FILE = grpc-standalone-server-integration-test-results.xml
run-grpc-standalone-integration-tests: ## run the grpc standalone integration tests
docker run --rm \
-v $(PWD):/app \
$(IMAGE_WITH_DEV_DEPS):$(IMAGE_TAG) \
poetry run \
pytest $(INTEGRATION_TEST_FOLDER)/test_standalone_grpc_server.py \
--junitxml=$(GRPC_STANDALONE_SERVER_INTEGRATION_TEST_RESULTS_FILE) \
--verbose
GRPC_SERVER_DOCKER_COMPOSE_FILE = $(GRPC_SERVER_INTEGRATION_TEST_FOLDER)/setup/docker-compose.yml
start-grpc-integration-test-env: ## run the rnv for the grpc integration tests
RASA_SDK_REPOSITORY=$(IMAGE_NAME) \
RASA_SDK_IMAGE_TAG=$(IMAGE_TAG) \
docker compose -f $(GRPC_SERVER_DOCKER_COMPOSE_FILE) up --wait
stop-grpc-integration-test-env: ## stop the env for the grpc integration tests
RASA_SDK_REPOSITORY=$(IMAGE_NAME) \
RASA_SDK_IMAGE_TAG=$(IMAGE_TAG) \
docker compose -f $(GRPC_SERVER_DOCKER_COMPOSE_FILE) down
GRPC_SERVER_DOCKER_INTEGRATION_TEST_RESULTS_FILE = grpc-server-docker-integration-test-results.xml
# Runs the gRPC integration tests in a docker container created from the image with dev dependencies
# Make sure to first start the environment with `make start-grpc-integration-test-env` before running this target
run-grpc-integration-tests: ## run the grpc integration tests
docker run --rm \
-v $(PWD):/app \
--network setup_rasa-pro-network \
-e GRPC_ACTION_SERVER_HOST="action-server-grpc-no-tls" \
-e GRPC_ACTION_SERVER_TLS_HOST="action-server-grpc-tls" \
$(IMAGE_WITH_DEV_DEPS):$(IMAGE_TAG) \
poetry run \
pytest $(GRPC_SERVER_INTEGRATION_TEST_FOLDER)/test_docker_grpc_server.py \
--junitxml=$(GRPC_SERVER_DOCKER_INTEGRATION_TEST_RESULTS_FILE) \
--verbose