Request matching - return known requests first (#3793)

This commit is contained in:
Bert Blommers 2021-08-28 13:34:32 +01:00 committed by GitHub
parent 9f47c0c7d3
commit 8f79edba38
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 99 additions and 5 deletions

View File

@ -200,6 +200,48 @@ jobs:
fail_ci_if_error: false fail_ci_if_error: false
flags: servertests flags: servertests
test_responses:
name: Test Responses==0.12.0
runs-on: ubuntu-latest
needs: lint
strategy:
matrix:
python-version: [ 3.7, 3.8 ]
steps:
- uses: actions/checkout@v2
with:
fetch-depth: 0
- name: Set up Python ${{ matrix.python-version }}
uses: actions/setup-python@v2
with:
python-version: ${{ matrix.python-version }}
- name: Get pip cache dir
id: pip-cache
run: |
echo "::set-output name=dir::$(pip cache dir)"
- name: pip cache
uses: actions/cache@v2
with:
path: ${{ steps.pip-cache.outputs.dir }}
key: pip-${{ matrix.python-version }}-${{ hashFiles('**/setup.py') }}-4
- name: Install project dependencies
run: |
python -m pip install --upgrade pip
pip install -r requirements-dev.txt
pip install pytest-cov
pip install responses==0.12.0
pip install "coverage<=4.5.4"
- name: Test core-logic with responses==0.12.0
run: |
pytest -sv --cov=moto --cov-report xml ./tests/test_core
- name: "Upload coverage to Codecov"
if: ${{ github.repository == 'spulec/moto'}}
uses: codecov/codecov-action@v1
with:
fail_ci_if_error: true
flags: test_responses
terraform: terraform:
name: Terraform Tests name: Terraform Tests
runs-on: ubuntu-latest runs-on: ubuntu-latest
@ -263,7 +305,7 @@ jobs:
deploy: deploy:
name: Deploy name: Deploy
runs-on: ubuntu-latest runs-on: ubuntu-latest
needs: [test, testserver, terraform] needs: [test, testserver, terraform, test_responses]
if: ${{ github.event_name == 'push' && github.ref == 'refs/heads/master' && github.repository == 'spulec/moto' }} if: ${{ github.event_name == 'push' && github.ref == 'refs/heads/master' && github.repository == 'spulec/moto' }}
strategy: strategy:
matrix: matrix:

View File

@ -1,7 +1,7 @@
codecov: codecov:
notify: notify:
# Leave a GitHub comment after all builds have passed # Leave a GitHub comment after all builds have passed
after_n_builds: 8 after_n_builds: 10
coverage: coverage:
status: status:
project: project:

View File

@ -286,22 +286,47 @@ responses_mock.add_passthru("http")
def _find_first_match_legacy(self, request): def _find_first_match_legacy(self, request):
matches = []
for i, match in enumerate(self._matches): for i, match in enumerate(self._matches):
if match.matches(request): if match.matches(request):
return match matches.append(match)
# Look for implemented callbacks first
implemented_matches = [
m
for m in matches
if type(m) is not CallbackResponse or m.callback != not_implemented_callback
]
if implemented_matches:
return implemented_matches[0]
elif matches:
# We had matches, but all were of type not_implemented_callback
return matches[0]
return None return None
def _find_first_match(self, request): def _find_first_match(self, request):
matches = []
match_failed_reasons = [] match_failed_reasons = []
for i, match in enumerate(self._matches): for i, match in enumerate(self._matches):
match_result, reason = match.matches(request) match_result, reason = match.matches(request)
if match_result: if match_result:
return match, match_failed_reasons matches.append(match)
else: else:
match_failed_reasons.append(reason) match_failed_reasons.append(reason)
# Look for implemented callbacks first
implemented_matches = [
m
for m in matches
if type(m) is not CallbackResponse or m.callback != not_implemented_callback
]
if implemented_matches:
return implemented_matches[0], []
elif matches:
# We had matches, but all were of type not_implemented_callback
return matches[0], match_failed_reasons
return None, match_failed_reasons return None, match_failed_reasons

View File

@ -3,7 +3,7 @@ import pytest
import sure # noqa import sure # noqa
import boto3 import boto3
from moto import mock_sqs, settings from moto import mock_s3, mock_sts, mock_sqs, settings
@mock_sqs @mock_sqs
@ -23,3 +23,30 @@ if not settings.TEST_SERVER_MODE:
res = requests.get("https://fakeservice.amazonaws.com/foo/bar") res = requests.get("https://fakeservice.amazonaws.com/foo/bar")
assert res.content == b"The method is not implemented" assert res.content == b"The method is not implemented"
assert res.status_code == 400 assert res.status_code == 400
@mock_sts
@mock_s3
def test_decorator_ordering():
"""
https://github.com/spulec/moto/issues/3790#issuecomment-803979809
"""
bucket_name = "banana-slugs"
key = "trash-file"
region = "us-east-1"
client = boto3.client("s3", region_name=region)
s3 = boto3.resource("s3", region_name=region)
bucket = s3.Bucket(bucket_name)
bucket.create()
bucket.put_object(Body=b"ABCD", Key=key)
presigned_url = client.generate_presigned_url(
ClientMethod=client.get_object.__name__,
Params={
"Bucket": bucket_name,
"Key": key,
"ResponseContentDisposition": "attachment;filename=bar",
},
)
resp = requests.get(presigned_url)
resp.status_code.should.equal(200)