awslabs.terraform-mcp-server 1.0.1__tar.gz → 1.0.2__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of awslabs.terraform-mcp-server might be problematic. Click here for more details.
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/Dockerfile +4 -4
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/PKG-INFO +4 -2
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/README.md +3 -1
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/pyproject.toml +1 -1
- awslabs_terraform_mcp_server-1.0.2/uv-requirements.txt +26 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/uv.lock +3 -3
- awslabs_terraform_mcp_server-1.0.1/.pre-commit-config.yaml +0 -14
- awslabs_terraform_mcp_server-1.0.1/run_tests.sh +0 -201
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/.gitignore +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/.python-version +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/CHANGELOG.md +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/__init__.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/terraform_mcp_server/__init__.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/terraform_mcp_server/impl/resources/__init__.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/terraform_mcp_server/impl/resources/terraform_aws_provider_resources_listing.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/terraform_mcp_server/impl/resources/terraform_awscc_provider_resources_listing.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/terraform_mcp_server/impl/tools/__init__.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/terraform_mcp_server/impl/tools/execute_terraform_command.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/terraform_mcp_server/impl/tools/execute_terragrunt_command.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/terraform_mcp_server/impl/tools/run_checkov_scan.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/terraform_mcp_server/impl/tools/search_aws_provider_docs.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/terraform_mcp_server/impl/tools/search_awscc_provider_docs.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/terraform_mcp_server/impl/tools/search_specific_aws_ia_modules.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/terraform_mcp_server/impl/tools/search_user_provided_module.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/terraform_mcp_server/impl/tools/utils.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/terraform_mcp_server/models/__init__.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/terraform_mcp_server/models/models.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/terraform_mcp_server/scripts/generate_aws_provider_resources.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/terraform_mcp_server/scripts/generate_awscc_provider_resources.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/terraform_mcp_server/scripts/scrape_aws_terraform_best_practices.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/terraform_mcp_server/server.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/terraform_mcp_server/static/AWSCC_PROVIDER_RESOURCES.md +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/terraform_mcp_server/static/AWS_PROVIDER_RESOURCES.md +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/terraform_mcp_server/static/AWS_TERRAFORM_BEST_PRACTICES.md +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/terraform_mcp_server/static/MCP_INSTRUCTIONS.md +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/terraform_mcp_server/static/TERRAFORM_WORKFLOW_GUIDE.md +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/terraform_mcp_server/static/__init__.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/docker-healthcheck.sh +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/tests/.gitignore +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/tests/README.md +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/tests/__init__.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/tests/conftest.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/tests/test_command_impl.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/tests/test_execute_terraform_command.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/tests/test_execute_terragrunt_command.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/tests/test_models.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/tests/test_parameter_annotations.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/tests/test_resources.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/tests/test_run_checkov_scan.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/tests/test_search_user_provided_module.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/tests/test_server.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/tests/test_tool_implementations.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/tests/test_utils.py +0 -0
- {awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/tests/test_utils_additional.py +0 -0
|
@@ -13,7 +13,7 @@
|
|
|
13
13
|
# limitations under the License.
|
|
14
14
|
|
|
15
15
|
#FROM public.ecr.aws/sam/build-python3.10:1.137.1-20250411084548
|
|
16
|
-
FROM public.ecr.aws/sam/build-python3.10@sha256:
|
|
16
|
+
FROM public.ecr.aws/sam/build-python3.10@sha256:d821662474d65f3cf2fc97dba2fa807a3adb580d02895fc4545527812550ea65 AS uv
|
|
17
17
|
|
|
18
18
|
# Install the project into `/app`
|
|
19
19
|
WORKDIR /app
|
|
@@ -31,11 +31,11 @@ ENV UV_PYTHON_PREFERENCE=only-system
|
|
|
31
31
|
ENV UV_FROZEN=true
|
|
32
32
|
|
|
33
33
|
# Copy the required files first
|
|
34
|
-
COPY pyproject.toml uv.lock ./
|
|
34
|
+
COPY pyproject.toml uv.lock uv-requirements.txt ./
|
|
35
35
|
|
|
36
36
|
# Install the project's dependencies using the lockfile and settings
|
|
37
37
|
RUN --mount=type=cache,target=/root/.cache/uv \
|
|
38
|
-
pip install uv && \
|
|
38
|
+
pip install --require-hashes --requirement uv-requirements.txt && \
|
|
39
39
|
uv sync --frozen --no-install-project --no-dev --no-editable
|
|
40
40
|
|
|
41
41
|
# Then, add the rest of the project source code and install it
|
|
@@ -47,7 +47,7 @@ RUN --mount=type=cache,target=/root/.cache/uv \
|
|
|
47
47
|
# Make the directory just in case it doesn't exist
|
|
48
48
|
RUN mkdir -p /root/.local
|
|
49
49
|
|
|
50
|
-
FROM public.ecr.aws/sam/build-python3.10@sha256:
|
|
50
|
+
FROM public.ecr.aws/sam/build-python3.10@sha256:d821662474d65f3cf2fc97dba2fa807a3adb580d02895fc4545527812550ea65
|
|
51
51
|
|
|
52
52
|
# Place executables in the environment at the front of the path and include other binaries
|
|
53
53
|
ENV PATH="/app/.venv/bin:$PATH:/usr/sbin"
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: awslabs.terraform-mcp-server
|
|
3
|
-
Version: 1.0.
|
|
3
|
+
Version: 1.0.2
|
|
4
4
|
Summary: An AWS Labs Model Context Protocol (MCP) server for terraform
|
|
5
5
|
Requires-Python: >=3.10
|
|
6
6
|
Requires-Dist: beautifulsoup4>=4.12.0
|
|
@@ -78,7 +78,9 @@ MCP server for Terraform on AWS best practices, infrastructure as code patterns,
|
|
|
78
78
|
|
|
79
79
|
## Installation
|
|
80
80
|
|
|
81
|
-
|
|
81
|
+
[](https://cursor.com/install-mcp?name=awslabs.terraform-mcp-server&config=eyJjb21tYW5kIjoidXZ4IGF3c2xhYnMudGVycmFmb3JtLW1jcC1zZXJ2ZXJAbGF0ZXN0IiwiZW52Ijp7IkZBU1RNQ1BfTE9HX0xFVkVMIjoiRVJST1IifSwiZGlzYWJsZWQiOmZhbHNlLCJhdXRvQXBwcm92ZSI6W119)
|
|
82
|
+
|
|
83
|
+
Configure the MCP server in your MCP client configuration (e.g., for Amazon Q Developer CLI, edit `~/.aws/amazonq/mcp.json`):
|
|
82
84
|
|
|
83
85
|
```json
|
|
84
86
|
{
|
|
@@ -63,7 +63,9 @@ MCP server for Terraform on AWS best practices, infrastructure as code patterns,
|
|
|
63
63
|
|
|
64
64
|
## Installation
|
|
65
65
|
|
|
66
|
-
|
|
66
|
+
[](https://cursor.com/install-mcp?name=awslabs.terraform-mcp-server&config=eyJjb21tYW5kIjoidXZ4IGF3c2xhYnMudGVycmFmb3JtLW1jcC1zZXJ2ZXJAbGF0ZXN0IiwiZW52Ijp7IkZBU1RNQ1BfTE9HX0xFVkVMIjoiRVJST1IifSwiZGlzYWJsZWQiOmZhbHNlLCJhdXRvQXBwcm92ZSI6W119)
|
|
67
|
+
|
|
68
|
+
Configure the MCP server in your MCP client configuration (e.g., for Amazon Q Developer CLI, edit `~/.aws/amazonq/mcp.json`):
|
|
67
69
|
|
|
68
70
|
```json
|
|
69
71
|
{
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
#
|
|
2
|
+
# This file is autogenerated by pip-compile with Python 3.10
|
|
3
|
+
# by the following command:
|
|
4
|
+
#
|
|
5
|
+
# pip-compile --generate-hashes --output-file=uv-requirements.txt --strip-extras uv-requirements-0.7.13.in
|
|
6
|
+
#
|
|
7
|
+
uv==0.7.13 \
|
|
8
|
+
--hash=sha256:05f3c03c4ea55d294f3da725b6c2c2ff544754c18552da7594def4ec3889dcfb \
|
|
9
|
+
--hash=sha256:1afdbfcabc3425b383141ba42d413841c0a48b9ee0f4da65459313275e3cea84 \
|
|
10
|
+
--hash=sha256:33837aca7bdf02d47554d5d44f9e71756ee17c97073b07b4afead25309855bc7 \
|
|
11
|
+
--hash=sha256:4efa555b217e15767f0691a51d435f7bb2b0bf473fdfd59f173aeda8a93b8d17 \
|
|
12
|
+
--hash=sha256:4f828174e15a557d3bc0f809de76135c3b66bcbf524657f8ced9d22fc978b89c \
|
|
13
|
+
--hash=sha256:527a12d0c2f4d15f72b275b6f4561ae92af76dd59b4624796fddd45867f13c33 \
|
|
14
|
+
--hash=sha256:5786a29e286f2cc3cbda13a357fd9a4dd5bf1d7448a9d3d842b26b4f784a3a86 \
|
|
15
|
+
--hash=sha256:59915aec9fd2b845708a76ddc6c0639cfc99b6e2811854ea2425ee7552aff0e9 \
|
|
16
|
+
--hash=sha256:721b058064150fc1c6d88e277af093d1b4f8bb7a59546fe9969d9ff7dbe3f6fd \
|
|
17
|
+
--hash=sha256:866cad0d04a7de1aaa3c5cbef203f9d3feef9655972dcccc3283d60122db743b \
|
|
18
|
+
--hash=sha256:88fcf2bfbb53309531a850af50d2ea75874099b19d4159625d0b4f88c53494b9 \
|
|
19
|
+
--hash=sha256:8c0c29a2089ff9011d6c3abccd272f3ee6d0e166dae9e5232099fd83d26104d9 \
|
|
20
|
+
--hash=sha256:9c457a84cfbe2019ba301e14edd3e1c950472abd0b87fc77622ab3fc475ba012 \
|
|
21
|
+
--hash=sha256:9d2952a1e74c7027347c74cee1cb2be09121a5290db38498b8b17ff585f73748 \
|
|
22
|
+
--hash=sha256:a51006c7574e819308d92a3452b22d5bd45ef8593a4983b5856aa7cb8220885f \
|
|
23
|
+
--hash=sha256:b1af81e57d098b21b28f42ec756f0e26dce2341d59ba4e4f11759bc3ca2c0a99 \
|
|
24
|
+
--hash=sha256:e077dcac19e564cae8b4223b7807c2f617a59938f8142ca77fc6348ae9c6d0aa \
|
|
25
|
+
--hash=sha256:f28e70baadfebe71dcc2d9505059b988d75e903fc62258b102eb87dc4b6994a3
|
|
26
|
+
# via -r uv-requirements-0.7.13.in (contents of `uv==0.7.13`)
|
|
@@ -949,11 +949,11 @@ wheels = [
|
|
|
949
949
|
|
|
950
950
|
[[package]]
|
|
951
951
|
name = "h11"
|
|
952
|
-
version = "0.
|
|
952
|
+
version = "0.16.0"
|
|
953
953
|
source = { registry = "https://pypi.org/simple" }
|
|
954
|
-
sdist = { url = "https://files.pythonhosted.org/packages/
|
|
954
|
+
sdist = { url = "https://files.pythonhosted.org/packages/01/ee/02a2c011bdab74c6fb3c75474d40b3052059d95df7e73351460c8588d963/h11-0.16.0.tar.gz", hash = "sha256:4e35b956cf45792e4caa5885e69fba00bdbc6ffafbfa020300e549b208ee5ff1", size = 101250, upload-time = "2025-04-24T03:35:25.427Z" }
|
|
955
955
|
wheels = [
|
|
956
|
-
{ url = "https://files.pythonhosted.org/packages/
|
|
956
|
+
{ url = "https://files.pythonhosted.org/packages/04/4b/29cac41a4d98d144bf5f6d33995617b185d14b22401f75ca86f384e87ff1/h11-0.16.0-py3-none-any.whl", hash = "sha256:63cf8bbe7522de3bf65932fda1d9c2772064ffb3dae62d55932da54b31cb6c86", size = 37515, upload-time = "2025-04-24T03:35:24.344Z" },
|
|
957
957
|
]
|
|
958
958
|
|
|
959
959
|
[[package]]
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
repos:
|
|
2
|
-
- repo: https://github.com/astral-sh/ruff-pre-commit
|
|
3
|
-
rev: v0.9.6
|
|
4
|
-
hooks:
|
|
5
|
-
- id: ruff
|
|
6
|
-
args: [--fix]
|
|
7
|
-
- id: ruff-format
|
|
8
|
-
|
|
9
|
-
- repo: https://github.com/commitizen-tools/commitizen
|
|
10
|
-
rev: v3.13.0
|
|
11
|
-
hooks:
|
|
12
|
-
- id: commitizen
|
|
13
|
-
- id: commitizen-branch
|
|
14
|
-
stages: [push]
|
|
@@ -1,201 +0,0 @@
|
|
|
1
|
-
#!/bin/bash
|
|
2
|
-
# Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
|
|
3
|
-
#
|
|
4
|
-
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
-
# you may not use this file except in compliance with the License.
|
|
6
|
-
# You may obtain a copy of the License at
|
|
7
|
-
#
|
|
8
|
-
# http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
-
#
|
|
10
|
-
# Unless required by applicable law or agreed to in writing, software
|
|
11
|
-
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
-
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
-
# See the License for the specific language governing permissions and
|
|
14
|
-
# limitations under the License.
|
|
15
|
-
|
|
16
|
-
# Script to run tests for the Terraform MCP Server
|
|
17
|
-
|
|
18
|
-
set -e
|
|
19
|
-
|
|
20
|
-
# Set the Python path to include the current directory and the parent directory
|
|
21
|
-
export PYTHONPATH=$PYTHONPATH:$(pwd):$(pwd)/..
|
|
22
|
-
|
|
23
|
-
# Check if we're in a virtual environment
|
|
24
|
-
if [ -z "$VIRTUAL_ENV" ]; then
|
|
25
|
-
echo "Warning: You are not running in a virtual environment."
|
|
26
|
-
echo "It's recommended to create and activate a virtual environment before running tests."
|
|
27
|
-
echo "You can create one with: python -m venv .venv"
|
|
28
|
-
echo "And activate it with: source .venv/bin/activate (Linux/Mac) or .venv\\Scripts\\activate (Windows)"
|
|
29
|
-
echo "Continuing without a virtual environment..."
|
|
30
|
-
echo ""
|
|
31
|
-
fi
|
|
32
|
-
echo "Python executable: $(which python)"
|
|
33
|
-
# Check if pytest and other dependencies are installed
|
|
34
|
-
echo "Checking for required packages..."
|
|
35
|
-
MISSING_PACKAGES=()
|
|
36
|
-
|
|
37
|
-
# Check for pytest and related packages
|
|
38
|
-
if ! python -c "import pytest" 2>/dev/null; then
|
|
39
|
-
MISSING_PACKAGES+=("pytest pytest-asyncio pytest-cov")
|
|
40
|
-
fi
|
|
41
|
-
|
|
42
|
-
# Check for pydantic package
|
|
43
|
-
if ! python -c "import pydantic" 2>/dev/null; then
|
|
44
|
-
MISSING_PACKAGES+=("pydantic")
|
|
45
|
-
fi
|
|
46
|
-
|
|
47
|
-
# Check for requests package
|
|
48
|
-
if ! python -c "import requests" 2>/dev/null; then
|
|
49
|
-
MISSING_PACKAGES+=("requests")
|
|
50
|
-
fi
|
|
51
|
-
|
|
52
|
-
# Check for loguru package
|
|
53
|
-
if ! python -c "import loguru" 2>/dev/null; then
|
|
54
|
-
MISSING_PACKAGES+=("loguru")
|
|
55
|
-
fi
|
|
56
|
-
|
|
57
|
-
# Check for beautifulsoup4 package
|
|
58
|
-
if ! python -c "import bs4" 2>/dev/null; then
|
|
59
|
-
MISSING_PACKAGES+=("beautifulsoup4")
|
|
60
|
-
fi
|
|
61
|
-
|
|
62
|
-
# Check for checkov package
|
|
63
|
-
if ! python -c "import checkov" 2>/dev/null; then
|
|
64
|
-
MISSING_PACKAGES+=("checkov")
|
|
65
|
-
fi
|
|
66
|
-
|
|
67
|
-
# Install missing packages
|
|
68
|
-
if [ ${#MISSING_PACKAGES[@]} -gt 0 ]; then
|
|
69
|
-
echo "Installing missing packages: ${MISSING_PACKAGES[*]}"
|
|
70
|
-
|
|
71
|
-
# Try pip first (more reliable)
|
|
72
|
-
if command -v pip &> /dev/null; then
|
|
73
|
-
echo "Using pip to install packages..."
|
|
74
|
-
pip install ${MISSING_PACKAGES[*]} -v
|
|
75
|
-
# Try pip3 if pip is not available
|
|
76
|
-
elif command -v pip3 &> /dev/null; then
|
|
77
|
-
echo "Using pip3 to install packages..."
|
|
78
|
-
pip3 install ${MISSING_PACKAGES[*]} -v
|
|
79
|
-
# Try uv as a last resort
|
|
80
|
-
elif command -v uv &> /dev/null; then
|
|
81
|
-
echo "Using uv to install packages..."
|
|
82
|
-
uv pip install ${MISSING_PACKAGES[*]} -v
|
|
83
|
-
else
|
|
84
|
-
echo "Error: No package manager (pip, pip3, or uv) is available. Please install the missing packages manually."
|
|
85
|
-
exit 1
|
|
86
|
-
fi
|
|
87
|
-
|
|
88
|
-
# Verify installation with more verbose output
|
|
89
|
-
echo "Verifying package installations..."
|
|
90
|
-
for pkg in "pytest" "pydantic" "requests" "loguru" "bs4" "checkov"; do
|
|
91
|
-
echo "Checking for $pkg..."
|
|
92
|
-
if ! python -c "import $pkg; print(f'$pkg installed successfully')"; then
|
|
93
|
-
echo "Failed to install $pkg. Trying to install it individually..."
|
|
94
|
-
pip install $pkg -v || pip3 install $pkg -v || echo "Failed to install $pkg. Please install it manually."
|
|
95
|
-
|
|
96
|
-
# Check again
|
|
97
|
-
if ! python -c "import $pkg" 2>/dev/null; then
|
|
98
|
-
echo "Still failed to install $pkg. Please install it manually."
|
|
99
|
-
echo "You can try: pip install $pkg"
|
|
100
|
-
exit 1
|
|
101
|
-
fi
|
|
102
|
-
fi
|
|
103
|
-
done
|
|
104
|
-
fi
|
|
105
|
-
|
|
106
|
-
# Print debug information
|
|
107
|
-
echo "Debug information:"
|
|
108
|
-
echo "Python version: $(python --version)"
|
|
109
|
-
echo "Python path: $PYTHONPATH"
|
|
110
|
-
echo "Current directory: $(pwd)"
|
|
111
|
-
echo "Python executable: $(which python)"
|
|
112
|
-
echo "Pytest module location: $(python -c "import pytest; print(pytest.__file__)" 2>/dev/null || echo "Not found")"
|
|
113
|
-
|
|
114
|
-
# Check if terraform_mcp_server module can be imported
|
|
115
|
-
echo "Checking if terraform_mcp_server module can be imported..."
|
|
116
|
-
python -c "import awslabs.terraform_mcp_server; print('terraform_mcp_server module found')" 2>/dev/null
|
|
117
|
-
if [ $? -ne 0 ]; then
|
|
118
|
-
echo "Warning: terraform_mcp_server module cannot be imported. This may cause test failures."
|
|
119
|
-
echo "Installing the package in development mode..."
|
|
120
|
-
|
|
121
|
-
# Check if uv is available
|
|
122
|
-
if command -v uv &> /dev/null; then
|
|
123
|
-
uv pip install -e .
|
|
124
|
-
# Check if pip is available
|
|
125
|
-
elif command -v pip &> /dev/null; then
|
|
126
|
-
pip install -e .
|
|
127
|
-
else
|
|
128
|
-
echo "Neither uv nor pip is available. Creating a symbolic link instead..."
|
|
129
|
-
# Create a symbolic link to the module in the current directory
|
|
130
|
-
ln -sf $(pwd)/awslabs/terraform_mcp_server $(pwd)/terraform_mcp_server 2>/dev/null
|
|
131
|
-
fi
|
|
132
|
-
|
|
133
|
-
echo "Trying again..."
|
|
134
|
-
python -c "import awslabs.terraform_mcp_server; print('terraform_mcp_server module found')" 2>/dev/null
|
|
135
|
-
if [ $? -ne 0 ]; then
|
|
136
|
-
echo "Still cannot import terraform_mcp_server module. Tests may fail."
|
|
137
|
-
echo "Directory structure:"
|
|
138
|
-
ls -la
|
|
139
|
-
echo "awslabs directory:"
|
|
140
|
-
ls -la awslabs 2>/dev/null || echo "awslabs directory not found"
|
|
141
|
-
fi
|
|
142
|
-
fi
|
|
143
|
-
|
|
144
|
-
# Parse command line arguments
|
|
145
|
-
COVERAGE=0
|
|
146
|
-
REPORT=0
|
|
147
|
-
VERBOSE=0
|
|
148
|
-
SPECIFIC_TEST=""
|
|
149
|
-
|
|
150
|
-
while [[ $# -gt 0 ]]; do
|
|
151
|
-
key="$1"
|
|
152
|
-
case $key in
|
|
153
|
-
--coverage)
|
|
154
|
-
COVERAGE=1
|
|
155
|
-
shift
|
|
156
|
-
;;
|
|
157
|
-
--report)
|
|
158
|
-
REPORT=1
|
|
159
|
-
shift
|
|
160
|
-
;;
|
|
161
|
-
--verbose)
|
|
162
|
-
VERBOSE=1
|
|
163
|
-
shift
|
|
164
|
-
;;
|
|
165
|
-
*)
|
|
166
|
-
SPECIFIC_TEST="$1"
|
|
167
|
-
shift
|
|
168
|
-
;;
|
|
169
|
-
esac
|
|
170
|
-
done
|
|
171
|
-
|
|
172
|
-
# Set up the command
|
|
173
|
-
CMD="python -m pytest"
|
|
174
|
-
|
|
175
|
-
if [ $VERBOSE -eq 1 ]; then
|
|
176
|
-
CMD="$CMD -v"
|
|
177
|
-
fi
|
|
178
|
-
|
|
179
|
-
if [ $COVERAGE -eq 1 ]; then
|
|
180
|
-
CMD="$CMD --cov=awslabs.terraform_mcp_server"
|
|
181
|
-
|
|
182
|
-
if [ $REPORT -eq 1 ]; then
|
|
183
|
-
CMD="$CMD --cov-report=html"
|
|
184
|
-
fi
|
|
185
|
-
fi
|
|
186
|
-
|
|
187
|
-
if [ -n "$SPECIFIC_TEST" ]; then
|
|
188
|
-
CMD="$CMD $SPECIFIC_TEST"
|
|
189
|
-
else
|
|
190
|
-
CMD="$CMD tests/"
|
|
191
|
-
fi
|
|
192
|
-
|
|
193
|
-
# Run the tests
|
|
194
|
-
echo "Running: $CMD"
|
|
195
|
-
$CMD
|
|
196
|
-
|
|
197
|
-
# If coverage report was generated, print the path
|
|
198
|
-
if [ $COVERAGE -eq 1 ] && [ $REPORT -eq 1 ]; then
|
|
199
|
-
echo "Coverage report generated in htmlcov/ directory"
|
|
200
|
-
echo "Open htmlcov/index.html in your browser to view the report"
|
|
201
|
-
fi
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/awslabs/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/docker-healthcheck.sh
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/tests/test_command_impl.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/tests/test_models.py
RENAMED
|
File without changes
|
|
File without changes
|
{awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/tests/test_resources.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/tests/test_server.py
RENAMED
|
File without changes
|
|
File without changes
|
{awslabs_terraform_mcp_server-1.0.1 → awslabs_terraform_mcp_server-1.0.2}/tests/test_utils.py
RENAMED
|
File without changes
|
|
File without changes
|