From 305460dc6aae5d2f71b5c625dd1056e986e72e8f Mon Sep 17 00:00:00 2001 From: Takashi Matsuo Date: Wed, 10 Jun 2020 12:45:41 -0700 Subject: [PATCH] [tasks] testing: use fixtures for the queue (#4049) fixes #4045 fixes #4044 I don't know why these tests started to fail, but anyways we'd better use fixtures and temporary queues. --- tasks/create_http_task_test.py | 24 +++++++++++++++++++++-- tasks/create_http_task_with_token_test.py | 24 +++++++++++++++++++++-- 2 files changed, 44 insertions(+), 4 deletions(-) diff --git a/tasks/create_http_task_test.py b/tasks/create_http_task_test.py index da61f11b63c2..b0fb3ed758b0 100644 --- a/tasks/create_http_task_test.py +++ b/tasks/create_http_task_test.py @@ -13,15 +13,35 @@ # limitations under the License. import os +import uuid + +from google.cloud import tasks_v2 +import pytest import create_http_task TEST_PROJECT_ID = os.getenv('GOOGLE_CLOUD_PROJECT') TEST_LOCATION = os.getenv('TEST_QUEUE_LOCATION', 'us-central1') -TEST_QUEUE_NAME = os.getenv('TEST_QUEUE_NAME', 'my-queue') +TEST_QUEUE_NAME = f'my-queue-{uuid.uuid4().hex}' + + +@pytest.fixture() +def test_queue(): + client = tasks_v2.CloudTasksClient() + parent = client.location_path(TEST_PROJECT_ID, TEST_LOCATION) + queue = { + # The fully qualified path to the queue + 'name': client.queue_path( + TEST_PROJECT_ID, TEST_LOCATION, TEST_QUEUE_NAME), + } + q = client.create_queue(parent, queue) + + yield q + + client.delete_queue(q.name) -def test_create_http_task(): +def test_create_http_task(test_queue): url = 'https://example.com/task_handler' result = create_http_task.create_http_task( TEST_PROJECT_ID, TEST_QUEUE_NAME, TEST_LOCATION, url) diff --git a/tasks/create_http_task_with_token_test.py b/tasks/create_http_task_with_token_test.py index 931cbd0ac295..dd90d9199b1e 100644 --- a/tasks/create_http_task_with_token_test.py +++ b/tasks/create_http_task_with_token_test.py @@ -13,17 +13,37 @@ # limitations under the License. import os +import uuid + +from google.cloud import tasks_v2 +import pytest import create_http_task_with_token TEST_PROJECT_ID = os.getenv('GOOGLE_CLOUD_PROJECT') TEST_LOCATION = os.getenv('TEST_QUEUE_LOCATION', 'us-central1') -TEST_QUEUE_NAME = os.getenv('TEST_QUEUE_NAME', 'my-queue') +TEST_QUEUE_NAME = f'my-queue-{uuid.uuid4().hex}' TEST_SERVICE_ACCOUNT = ( 'test-run-invoker@python-docs-samples-tests.iam.gserviceaccount.com') -def test_create_http_task_with_token(): +@pytest.fixture() +def test_queue(): + client = tasks_v2.CloudTasksClient() + parent = client.location_path(TEST_PROJECT_ID, TEST_LOCATION) + queue = { + # The fully qualified path to the queue + 'name': client.queue_path( + TEST_PROJECT_ID, TEST_LOCATION, TEST_QUEUE_NAME), + } + q = client.create_queue(parent, queue) + + yield q + + client.delete_queue(q.name) + + +def test_create_http_task_with_token(test_queue): url = 'https://example.com/task_handler' result = create_http_task_with_token.create_http_task(TEST_PROJECT_ID, TEST_QUEUE_NAME,