Skip to content

Commit

Permalink
fix(connector) Use intake URL from file
Browse files Browse the repository at this point in the history
fix

new version

remove extra space

run ruff changelog and version

run black

Add test

update

black

fix tests

again
  • Loading branch information
StephKll3c committed Mar 26, 2024
1 parent e9192b2 commit a1c8762
Show file tree
Hide file tree
Showing 8 changed files with 39 additions and 14 deletions.
6 changes: 6 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,12 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0

## [Unreleased]

## [1.12.2] - 2024-03-26

### Fixed

- Use file for batch url computation

## [1.12.1] - 2024-03-22

### Fixed
Expand Down
2 changes: 1 addition & 1 deletion pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ build-backend = "poetry.core.masonry.api"
[tool.poetry]
name = "sekoia-automation-sdk"

version = "1.12.1"
version = "1.12.2"
description = "SDK to create Sekoia.io playbook modules"
license = "MIT"
readme = "README.md"
Expand Down
7 changes: 4 additions & 3 deletions sekoia_automation/aio/connector.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
"""Contains connector with async version."""

import os
from abc import ABC
from asyncio import AbstractEventLoop, get_event_loop
from collections.abc import AsyncGenerator
Expand Down Expand Up @@ -154,8 +153,10 @@ async def push_data_to_intakes(
list[str]:
"""
self._last_events_time = datetime.utcnow()
intake_host = os.getenv("INTAKE_URL", self.configuration.intake_server)
batch_api = urljoin(intake_host, "batch")
if intake_server := self.configuration.intake_server:
batch_api = urljoin(intake_server, "batch")
else:
batch_api = urljoin(self.intake_url, "batch")

result_ids = []

Expand Down
9 changes: 5 additions & 4 deletions sekoia_automation/connector/__init__.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
import os
import uuid
from abc import ABC
from collections.abc import Generator, Sequence
Expand Down Expand Up @@ -36,7 +35,7 @@


class DefaultConnectorConfiguration(BaseModel):
intake_server: str = "https://intake.sekoia.io"
intake_server: str | None = None
intake_key: str


Expand Down Expand Up @@ -171,8 +170,10 @@ def push_events_to_intakes(
# Reset the consecutive error count
self._error_count = 0
self._last_events_time = datetime.utcnow()
intake_host = os.getenv("INTAKE_URL", self.configuration.intake_server)
batch_api = urljoin(intake_host, "batch")
if intake_server := self.configuration.intake_server:
batch_api = urljoin(intake_server, "batch")
else:
batch_api = urljoin(self.intake_url, "batch")

# Dict to collect event_ids for the API
collect_ids: dict[int, list] = {}
Expand Down
5 changes: 5 additions & 0 deletions sekoia_automation/module.py
Original file line number Diff line number Diff line change
Expand Up @@ -322,6 +322,7 @@ class ModuleItem(ABC):
CALLBACK_URL_FILE_NAME = "url_callback"
SECRETS_URL_FILE_NAME = "url_secrets"
LOGS_URL_FILE_NAME = "url_logs"
INTAKE_URL_FILE_NAME = "intake_url"

name: str | None = None
description: str | None = None
Expand Down Expand Up @@ -419,6 +420,10 @@ def secrets_url(self) -> str:
except FileNotFoundError:
return self.callback_url.replace("/callback", "/secrets")

@cached_property
def intake_url(self) -> str:
return self.module.load_config(self.INTAKE_URL_FILE_NAME)

@property
def _headers(self) -> dict[str, str]:
return {"Authorization": f"Bearer {self.token}"}
Expand Down
12 changes: 7 additions & 5 deletions tests/aio/test_connector.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
"""Test async connector."""

from unittest.mock import Mock, patch
import json
from unittest.mock import Mock, mock_open, patch
from urllib.parse import urljoin

import pytest
Expand Down Expand Up @@ -91,7 +92,8 @@ async def test_async_connector_client_session(async_connector: DummyAsyncConnect
DummyAsyncConnector.set_rate_limiter(None)
other_instance.set_client_session(None)


@patch("builtins.open", new_callable=mock_open,
read_data=json.dumps({"intake_url": "https://intake.sekoia.io"}))
@pytest.mark.asyncio
async def test_async_connector_push_single_event(
async_connector: DummyAsyncConnector, faker: Faker
Expand All @@ -116,7 +118,7 @@ async def test_async_connector_push_single_event(

single_event_id = faker.uuid4()

request_url = urljoin(async_connector.configuration.intake_server, "batch")
request_url = urljoin("https://intake.sekoia.io", "batch")

with aioresponses() as mocked_responses:
mocked_responses.post(
Expand Down Expand Up @@ -155,7 +157,7 @@ async def test_async_connector_push_multiple_events(

single_event_id = faker.uuid4()

request_url = urljoin(async_connector.configuration.intake_server, "batch")
request_url = urljoin("https://intake.sekoia.io", "batch")

with (
aioresponses() as mocked_responses,
Expand Down Expand Up @@ -200,7 +202,7 @@ async def test_async_connector_raise_error(
stop=stop_after_attempt(1),
)

request_url = urljoin(async_connector.configuration.intake_server, "batch")
request_url = urljoin("https://intake.sekoia.io", "batch")

with (
aioresponses() as mocked_responses,
Expand Down
5 changes: 4 additions & 1 deletion tests/connectors/test_connector.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import json
import os
from unittest.mock import Mock, PropertyMock, patch
from unittest.mock import Mock, PropertyMock, mock_open, patch

import pytest
from tenacity import Retrying, stop_after_attempt, wait_none
Expand Down Expand Up @@ -104,6 +105,8 @@ def test_chunk_events_discard_too_long_message(test_connector):
assert test_connector.log.called


@patch("builtins.open", new_callable=mock_open,
read_data=json.dumps({"intake_url": "https://intake.sekoia.io/batch"}))
def test_push_event_to_intake_with_2_events(test_connector, mocked_trigger_logs):
url = "https://intake.sekoia.io/batch"
mocked_trigger_logs.post(url, json={"event_ids": ["001", "002"]})
Expand Down
7 changes: 7 additions & 0 deletions tests/test_trigger.py
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,13 @@ def test_secrets_url():
mock.assert_called_with(trigger.SECRETS_URL_FILE_NAME)


def test_intake_url():
trigger = DummyTrigger()
with patch.object(Module, "load_config", return_value="intake") as mock:
assert trigger.intake_url == "intake"
mock.assert_called_with(trigger.INTAKE_URL_FILE_NAME)


def test_logs_url():
trigger = DummyTrigger()
with patch.object(Module, "load_config", return_value="logs") as mock:
Expand Down

0 comments on commit a1c8762

Please sign in to comment.