Skip to content

Commit

Permalink
[feat] Add support for ms graph (#41)
Browse files Browse the repository at this point in the history
  • Loading branch information
aquamatthias authored Jul 23, 2024
1 parent 3e32270 commit 04fd40e
Show file tree
Hide file tree
Showing 2 changed files with 44 additions and 7 deletions.
1 change: 1 addition & 0 deletions collect_coordinator/worker_queue.py
Original file line number Diff line number Diff line change
Expand Up @@ -184,6 +184,7 @@ def handle_azure_subscription() -> None:
"accounts": {
"default": {
"subscriptions": [az_subscription_id],
"collect_microsoft_graph": account.get("collect_microsoft_graph", False),
"client_secret": {
"tenant_id": az_tenant_id,
"client_id": az_client_id,
Expand Down
50 changes: 43 additions & 7 deletions tests/worker_queue_test.py
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@


@fixture
def example_collect_definition() -> Json:
def example_aws_collect_definition() -> Json:
return {
"job_id": "uid",
"tenant_id": "a",
Expand All @@ -56,6 +56,27 @@ def example_collect_definition() -> Json:
}


@fixture
def example_azure_collect_definition() -> Json:
return {
"job_id": "uid",
"tenant_id": "a",
"graphdb_server": "b",
"graphdb_database": "c",
"graphdb_username": "d",
"graphdb_password": "e",
"account": {
"kind": "azure_subscription_information",
"azure_subscription_id": "123",
"tenant_id": "123",
"client_id": "234",
"client_secret": "bombproof",
"collect_microsoft_graph": False,
},
"env": {"test": "test"},
}


@fixture
def example_post_collect_definition() -> Json:
return {
Expand All @@ -75,8 +96,20 @@ def example_post_collect_definition() -> Json:


@pytest.mark.skipif(os.environ.get("REDIS_RUNNING", "false") != "true", reason="Redis not running")
def test_read_job_definition(worker_queue: WorkerQueue, example_collect_definition: Json) -> None:
job_def = worker_queue.parse_collect_definition_json(example_collect_definition)
def test_read_azure_job_definition(worker_queue: WorkerQueue, example_azure_collect_definition: Json) -> None:
job_def = worker_queue.parse_collect_definition_json(example_azure_collect_definition)
assert (
job_def.env
and job_def.env["WORKER_CONFIG"]
== '{"azure": {"accounts": {"default": {"subscriptions": ["123"], "collect_microsoft_graph": false, '
'"client_secret": {"tenant_id": "123", "client_id": "234", "client_secret": "bombproof"}}}}, '
'"fixworker": {"collector": ["azure"]}}'
)


@pytest.mark.skipif(os.environ.get("REDIS_RUNNING", "false") != "true", reason="Redis not running")
def test_read_aws_job_definition(worker_queue: WorkerQueue, example_aws_collect_definition: Json) -> None:
job_def = worker_queue.parse_collect_definition_json(example_aws_collect_definition)
assert job_def.name.startswith("collect")
assert job_def.image == "someengineering/fix-collect-single:0.0.1"
# fmt: off
Expand Down Expand Up @@ -149,12 +182,15 @@ def test_read_post_job_definition(worker_queue: WorkerQueue, example_post_collec
@pytest.mark.asyncio
@pytest.mark.skipif(os.environ.get("REDIS_RUNNING", "false") != "true", reason="Redis not running")
async def test_enqueue_jobs(
arq_redis: ArqRedis, worker_queue: WorkerQueue, coordinator: LazyJobCoordinator, example_collect_definition: Json
arq_redis: ArqRedis,
worker_queue: WorkerQueue,
coordinator: LazyJobCoordinator,
example_aws_collect_definition: Json,
) -> None:
async with worker_queue:
await arq_redis.enqueue_job("collect", example_collect_definition)
await arq_redis.enqueue_job("collect", example_collect_definition)
await arq_redis.enqueue_job("collect", example_collect_definition)
await arq_redis.enqueue_job("collect", example_aws_collect_definition)
await arq_redis.enqueue_job("collect", example_aws_collect_definition)
await arq_redis.enqueue_job("collect", example_aws_collect_definition)
ping = await arq_redis.enqueue_job("ping")
assert ping is not None

Expand Down

0 comments on commit 04fd40e

Please sign in to comment.