From 6267dc961fa78a1354ca303e75c5dacd42b07a85 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Edgar=20Ram=C3=ADrez-Mondrag=C3=B3n?= Date: Tue, 17 Dec 2024 10:49:44 -0600 Subject: [PATCH 1/9] fix: Fix `TypeError` in record generation --- .github/workflows/validate.yml | 53 +++++++++++++++++++++++++++++----- .python-version | 2 +- poetry.lock | 32 ++++++++++---------- tap_mongodb/streams.py | 2 +- 4 files changed, 64 insertions(+), 25 deletions(-) diff --git a/.github/workflows/validate.yml b/.github/workflows/validate.yml index 6d6dabf..1b1b21a 100644 --- a/.github/workflows/validate.yml +++ b/.github/workflows/validate.yml @@ -26,11 +26,11 @@ jobs: - '3.13' steps: - name: Checkout - uses: actions/checkout@v3 + uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 - name: Install poetry run: pipx install poetry - name: Set up Python ${{ matrix.python-version }} - uses: actions/setup-python@v4 + uses: actions/setup-python@0b93645e9fea7318ecaed2b359559ac225c90a2b # v5.3.0 with: python-version: ${{ matrix.python-version }} cache: poetry @@ -39,7 +39,8 @@ jobs: poetry env use ${{ matrix.python-version }} poetry install - name: Run pre-commit checks - uses: pre-commit/action@v3.0.0 + uses: pre-commit/action@2c7b3805fd2a0fd8c1884dcaebf91fc102a13ecd # v3.0.1 + smoke-test: runs-on: ubuntu-latest strategy: @@ -54,9 +55,9 @@ jobs: - '3.13' steps: - name: Checkout - uses: actions/checkout@v3 + uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 - name: Set up Python ${{ matrix.python-version }} - uses: actions/setup-python@v4 + uses: actions/setup-python@0b93645e9fea7318ecaed2b359559ac225c90a2b # v5.3.0 with: python-version: ${{ matrix.python-version }} - name: Install meltano @@ -65,6 +66,7 @@ jobs: run: meltano install - name: Smoke test run: meltano invoke tap-mongodb --about + test: runs-on: ubuntu-latest strategy: @@ -81,11 +83,11 @@ jobs: - '3.12' - '3.13' steps: - - uses: actions/checkout@v3 + - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 - name: Install poetry run: pipx install poetry - name: Set up Python ${{ matrix.python-version }} - uses: actions/setup-python@v4 + uses: actions/setup-python@0b93645e9fea7318ecaed2b359559ac225c90a2b # v5.3.0 with: python-version: ${{ matrix.python-version }} cache: poetry @@ -94,7 +96,7 @@ jobs: poetry env use ${{ matrix.python-version }} poetry install - name: Start MongoDB - uses: supercharge/mongodb-github-action@1.9.0 + uses: supercharge/mongodb-github-action@5a87bd81f88e2a8b195f8b7b656f5cda1350815a # 1.11.0 with: mongodb-version: ${{ matrix.mongo-version }} mongodb-username: admin @@ -102,3 +104,38 @@ jobs: mongodb-db: test - name: Test with pytest run: poetry run pytest + + integration: + runs-on: ubuntu-latest + name: Meltano integration test 🐉 + env: + DATABASE: test + USERNAME: admin + PASSWORD: password + strategy: + matrix: + mongodb-version: [6.0, 7.0] + + steps: + - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 + - name: Start MongoDB + uses: supercharge/mongodb-github-action@5a87bd81f88e2a8b195f8b7b656f5cda1350815a # 1.11.0 + with: + mongodb-version: ${{ matrix.mongodb-version }} + mongodb-username: ${{ env.USERNAME }} + mongodb-password: ${{ env.PASSWORD }} + mongodb-db: ${{ env.DATABASE }} + - uses: actions/setup-python@0b93645e9fea7318ecaed2b359559ac225c90a2b # v5.3.0 + with: + python-version: '3.x' + - uses: astral-sh/setup-uv@38f3f104447c67c051c4a08e39b64a148898af3a # v4.2.0 + with: + version: ">=0.5" + - name: Install Meltano + run: uv tool install meltano + - run: meltano config meltano set venv.backend uv + - run: | + meltano run tap-mongodb target-jsonl + env: + TAP_MONGODB_DATABASE: ${{ env.DATABASE }} + TAP_MONGODB_MONGODB_CONNECTION_STRING: mongodb://${{ env.USERNAME }}:${{ env.PASSWORD }}@localhost:27017/ diff --git a/.python-version b/.python-version index 371cfe3..24ee5b1 100644 --- a/.python-version +++ b/.python-version @@ -1 +1 @@ -3.11.1 +3.13 diff --git a/poetry.lock b/poetry.lock index aec8c1a..b9464d9 100644 --- a/poetry.lock +++ b/poetry.lock @@ -27,19 +27,19 @@ typing-extensions = {version = ">=4.0.0", markers = "python_version < \"3.11\""} [[package]] name = "attrs" -version = "24.2.0" +version = "24.3.0" description = "Classes Without Boilerplate" optional = false -python-versions = ">=3.7" +python-versions = ">=3.8" files = [ - {file = "attrs-24.2.0-py3-none-any.whl", hash = "sha256:81921eb96de3191c8258c199618104dd27ac608d9366f5e35d011eae1867ede2"}, - {file = "attrs-24.2.0.tar.gz", hash = "sha256:5cfb1b9148b5b086569baec03f20d7b6bf3bcacc9a42bebf87ffaaca362f6346"}, + {file = "attrs-24.3.0-py3-none-any.whl", hash = "sha256:ac96cd038792094f438ad1f6ff80837353805ac950cd2aa0e0625ef19850c308"}, + {file = "attrs-24.3.0.tar.gz", hash = "sha256:8f5c07333d543103541ba7be0e2ce16eeee8130cb0b3f9238ab904ce1e85baff"}, ] [package.extras] benchmark = ["cloudpickle", "hypothesis", "mypy (>=1.11.1)", "pympler", "pytest (>=4.3.0)", "pytest-codspeed", "pytest-mypy-plugins", "pytest-xdist[psutil]"] cov = ["cloudpickle", "coverage[toml] (>=5.3)", "hypothesis", "mypy (>=1.11.1)", "pympler", "pytest (>=4.3.0)", "pytest-mypy-plugins", "pytest-xdist[psutil]"] -dev = ["cloudpickle", "hypothesis", "mypy (>=1.11.1)", "pre-commit", "pympler", "pytest (>=4.3.0)", "pytest-mypy-plugins", "pytest-xdist[psutil]"] +dev = ["cloudpickle", "hypothesis", "mypy (>=1.11.1)", "pre-commit-uv", "pympler", "pytest (>=4.3.0)", "pytest-mypy-plugins", "pytest-xdist[psutil]"] docs = ["cogapp", "furo", "myst-parser", "sphinx", "sphinx-notfound-page", "sphinxcontrib-towncrier", "towncrier (<24.7)"] tests = ["cloudpickle", "hypothesis", "mypy (>=1.11.1)", "pympler", "pytest (>=4.3.0)", "pytest-mypy-plugins", "pytest-xdist[psutil]"] tests-mypy = ["mypy (>=1.11.1)", "pytest-mypy-plugins"] @@ -159,17 +159,17 @@ uvloop = ["uvloop (>=0.15.2)"] [[package]] name = "boto3" -version = "1.35.79" +version = "1.35.82" description = "The AWS SDK for Python" optional = true python-versions = ">=3.8" files = [ - {file = "boto3-1.35.79-py3-none-any.whl", hash = "sha256:a673b0b6378c9ccbf045a31a43195b175e12aa5c37fb7635fcbfc8f48fb857b3"}, - {file = "boto3-1.35.79.tar.gz", hash = "sha256:1fa26217cd33ded82e55aed4460cd55f7223fa647916aa0d3c5d6828e6ec7135"}, + {file = "boto3-1.35.82-py3-none-any.whl", hash = "sha256:c422b68ae76959b9e23b77eb79e41c3483332f7e1de918d2b083c456d8cf234c"}, + {file = "boto3-1.35.82.tar.gz", hash = "sha256:2bbaf1551b1ed55770cb437d7040f1abe6742601103695057b30ce6328eef286"}, ] [package.dependencies] -botocore = ">=1.35.79,<1.36.0" +botocore = ">=1.35.82,<1.36.0" jmespath = ">=0.7.1,<2.0.0" s3transfer = ">=0.10.0,<0.11.0" @@ -178,13 +178,13 @@ crt = ["botocore[crt] (>=1.21.0,<2.0a0)"] [[package]] name = "botocore" -version = "1.35.79" +version = "1.35.82" description = "Low-level, data-driven core of boto 3." optional = true python-versions = ">=3.8" files = [ - {file = "botocore-1.35.79-py3-none-any.whl", hash = "sha256:e6b10bb9a357e3f5ca2e60f6dd15a85d311b9a476eb21b3c0c2a3b364a2897c8"}, - {file = "botocore-1.35.79.tar.gz", hash = "sha256:245bfdda1b1508539ddd1819c67a8a2cc81780adf0715d3de418d64c4247f346"}, + {file = "botocore-1.35.82-py3-none-any.whl", hash = "sha256:e43b97d8cbf19d35ce3a177f144bd97cc370f0a67d0984c7d7cf105ac198748f"}, + {file = "botocore-1.35.82.tar.gz", hash = "sha256:78dd7bf8f49616d00073698d7bbaf5a115208fe730b7b7afae4456adddb3552e"}, ] [package.dependencies] @@ -200,13 +200,13 @@ crt = ["awscrt (==0.22.0)"] [[package]] name = "certifi" -version = "2024.8.30" +version = "2024.12.14" description = "Python package for providing Mozilla's CA Bundle." optional = false python-versions = ">=3.6" files = [ - {file = "certifi-2024.8.30-py3-none-any.whl", hash = "sha256:922820b53db7a7257ffbda3f597266d435245903d80737e34f8a45ff3e3230d8"}, - {file = "certifi-2024.8.30.tar.gz", hash = "sha256:bec941d2aa8195e248a60b31ff9f0558284cf01a52591ceda73ea9afffd69fd9"}, + {file = "certifi-2024.12.14-py3-none-any.whl", hash = "sha256:1275f7a45be9464efc1173084eaa30f866fe2e47d389406136d332ed4967ec56"}, + {file = "certifi-2024.12.14.tar.gz", hash = "sha256:b650d30f370c2b724812bee08008be0c4163b163ddaec3f2546c1caf65f191db"}, ] [[package]] @@ -709,6 +709,8 @@ optional = false python-versions = "*" files = [ {file = "jsonpath-ng-1.7.0.tar.gz", hash = "sha256:f6f5f7fd4e5ff79c785f1573b394043b39849fb2bb47bcead935d12b00beab3c"}, + {file = "jsonpath_ng-1.7.0-py2-none-any.whl", hash = "sha256:898c93fc173f0c336784a3fa63d7434297544b7198124a68f9a3ef9597b0ae6e"}, + {file = "jsonpath_ng-1.7.0-py3-none-any.whl", hash = "sha256:f3d7f9e848cba1b6da28c55b1c26ff915dc9e0b1ba7e752a53d6da8d5cbd00b6"}, ] [package.dependencies] diff --git a/tap_mongodb/streams.py b/tap_mongodb/streams.py index eb17c36..a12546e 100644 --- a/tap_mongodb/streams.py +++ b/tap_mongodb/streams.py @@ -178,7 +178,7 @@ def _generate_record_messages(self, record: dict) -> Generator[singer.RecordMess Record message objects. """ extracted_at: datetime = record.pop("_sdc_extracted_at", utc_now()) - pop_deselected_record_properties(record, self.schema, self.mask, self.logger) + pop_deselected_record_properties(record, self.schema, self.mask) record = conform_record_data_types( stream_name=self.name, record=record, From d2f7afed9f2de03651f426800adc61c4225d7555 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Edgar=20Ram=C3=ADrez-Mondrag=C3=B3n?= Date: Tue, 17 Dec 2024 10:54:13 -0600 Subject: [PATCH 2/9] Lint YAML files --- .github/workflows/validate.yml | 36 ++++++++++++++++------------------ 1 file changed, 17 insertions(+), 19 deletions(-) diff --git a/.github/workflows/validate.yml b/.github/workflows/validate.yml index 1b1b21a..2801451 100644 --- a/.github/workflows/validate.yml +++ b/.github/workflows/validate.yml @@ -26,11 +26,11 @@ jobs: - '3.13' steps: - name: Checkout - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 + uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 - name: Install poetry run: pipx install poetry - name: Set up Python ${{ matrix.python-version }} - uses: actions/setup-python@0b93645e9fea7318ecaed2b359559ac225c90a2b # v5.3.0 + uses: actions/setup-python@0b93645e9fea7318ecaed2b359559ac225c90a2b # v5.3.0 with: python-version: ${{ matrix.python-version }} cache: poetry @@ -39,8 +39,7 @@ jobs: poetry env use ${{ matrix.python-version }} poetry install - name: Run pre-commit checks - uses: pre-commit/action@2c7b3805fd2a0fd8c1884dcaebf91fc102a13ecd # v3.0.1 - + uses: pre-commit/action@2c7b3805fd2a0fd8c1884dcaebf91fc102a13ecd # v3.0.1 smoke-test: runs-on: ubuntu-latest strategy: @@ -55,9 +54,9 @@ jobs: - '3.13' steps: - name: Checkout - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 + uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 - name: Set up Python ${{ matrix.python-version }} - uses: actions/setup-python@0b93645e9fea7318ecaed2b359559ac225c90a2b # v5.3.0 + uses: actions/setup-python@0b93645e9fea7318ecaed2b359559ac225c90a2b # v5.3.0 with: python-version: ${{ matrix.python-version }} - name: Install meltano @@ -66,7 +65,6 @@ jobs: run: meltano install - name: Smoke test run: meltano invoke tap-mongodb --about - test: runs-on: ubuntu-latest strategy: @@ -83,11 +81,11 @@ jobs: - '3.12' - '3.13' steps: - - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 + - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 - name: Install poetry run: pipx install poetry - name: Set up Python ${{ matrix.python-version }} - uses: actions/setup-python@0b93645e9fea7318ecaed2b359559ac225c90a2b # v5.3.0 + uses: actions/setup-python@0b93645e9fea7318ecaed2b359559ac225c90a2b # v5.3.0 with: python-version: ${{ matrix.python-version }} cache: poetry @@ -96,7 +94,7 @@ jobs: poetry env use ${{ matrix.python-version }} poetry install - name: Start MongoDB - uses: supercharge/mongodb-github-action@5a87bd81f88e2a8b195f8b7b656f5cda1350815a # 1.11.0 + uses: supercharge/mongodb-github-action@5a87bd81f88e2a8b195f8b7b656f5cda1350815a # 1.11.0 with: mongodb-version: ${{ matrix.mongo-version }} mongodb-username: admin @@ -104,7 +102,6 @@ jobs: mongodb-db: test - name: Test with pytest run: poetry run pytest - integration: runs-on: ubuntu-latest name: Meltano integration test 🐉 @@ -114,23 +111,24 @@ jobs: PASSWORD: password strategy: matrix: - mongodb-version: [6.0, 7.0] - + mongodb-version: + - '6.0' + - '7.0' steps: - - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 + - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 - name: Start MongoDB - uses: supercharge/mongodb-github-action@5a87bd81f88e2a8b195f8b7b656f5cda1350815a # 1.11.0 + uses: supercharge/mongodb-github-action@5a87bd81f88e2a8b195f8b7b656f5cda1350815a # 1.11.0 with: mongodb-version: ${{ matrix.mongodb-version }} mongodb-username: ${{ env.USERNAME }} mongodb-password: ${{ env.PASSWORD }} mongodb-db: ${{ env.DATABASE }} - - uses: actions/setup-python@0b93645e9fea7318ecaed2b359559ac225c90a2b # v5.3.0 + - uses: actions/setup-python@0b93645e9fea7318ecaed2b359559ac225c90a2b # v5.3.0 with: - python-version: '3.x' - - uses: astral-sh/setup-uv@38f3f104447c67c051c4a08e39b64a148898af3a # v4.2.0 + python-version: 3.x + - uses: astral-sh/setup-uv@38f3f104447c67c051c4a08e39b64a148898af3a # v4.2.0 with: - version: ">=0.5" + version: '>=0.5' - name: Install Meltano run: uv tool install meltano - run: meltano config meltano set venv.backend uv From 084e1ba70ee5316b37d61d300f2968657a888c8e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Edgar=20Ram=C3=ADrez-Mondrag=C3=B3n?= Date: Tue, 17 Dec 2024 11:08:05 -0600 Subject: [PATCH 3/9] Seed database --- .github/workflows/validate.yml | 10 ++++- poetry.lock | 19 ++++++++- pyproject.toml | 1 + scripts/seed.py | 70 ++++++++++++++++++++++++++++++++++ 4 files changed, 96 insertions(+), 4 deletions(-) create mode 100644 scripts/seed.py diff --git a/.github/workflows/validate.yml b/.github/workflows/validate.yml index 2801451..d2deddb 100644 --- a/.github/workflows/validate.yml +++ b/.github/workflows/validate.yml @@ -132,8 +132,14 @@ jobs: - name: Install Meltano run: uv tool install meltano - run: meltano config meltano set venv.backend uv - - run: | - meltano run tap-mongodb target-jsonl + - run: > + uv run seed.py + --host localhost + --port 27017 + --database ${{ env.DATABASE }} + --username ${{ env.USERNAME }} + --password ${{ env.PASSWORD }} + - run: meltano run tap-mongodb target-jsonl env: TAP_MONGODB_DATABASE: ${{ env.DATABASE }} TAP_MONGODB_MONGODB_CONNECTION_STRING: mongodb://${{ env.USERNAME }}:${{ env.PASSWORD }}@localhost:27017/ diff --git a/poetry.lock b/poetry.lock index b9464d9..9800403 100644 --- a/poetry.lock +++ b/poetry.lock @@ -408,6 +408,21 @@ files = [ [package.extras] test = ["pytest (>=6)"] +[[package]] +name = "faker" +version = "33.1.0" +description = "Faker is a Python package that generates fake data for you." +optional = false +python-versions = ">=3.8" +files = [ + {file = "Faker-33.1.0-py3-none-any.whl", hash = "sha256:d30c5f0e2796b8970de68978365247657486eb0311c5abe88d0b895b68dff05d"}, + {file = "faker-33.1.0.tar.gz", hash = "sha256:1c925fc0e86a51fc46648b504078c88d0cd48da1da2595c4e712841cab43a1e4"}, +] + +[package.dependencies] +python-dateutil = ">=2.4" +typing-extensions = "*" + [[package]] name = "flake8" version = "5.0.4" @@ -1063,7 +1078,7 @@ testing = ["argcomplete", "attrs (>=19.2.0)", "hypothesis (>=3.56)", "mock", "no name = "python-dateutil" version = "2.9.0.post0" description = "Extensions to the standard Python datetime module" -optional = true +optional = false python-versions = "!=3.0.*,!=3.1.*,!=3.2.*,>=2.7" files = [ {file = "python-dateutil-2.9.0.post0.tar.gz", hash = "sha256:37dd54208da7e1cd875388217d5e00ebd4179249f90fb72437e91a35459a0ad3"}, @@ -1769,4 +1784,4 @@ s3 = ["fs-s3fs"] [metadata] lock-version = "2.0" python-versions = "^3.8" -content-hash = "5598a5d9dd2f985bdfc7e723afceee594c203ca89a56a81e2dcd39895b37b4f8" +content-hash = "1d272e1297d48f9466300c7dc1e648917be1554094ec6021e9ae668c5354529f" diff --git a/pyproject.toml b/pyproject.toml index b9e6a3a..575d955 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -29,6 +29,7 @@ mypy = "^1.0.0" isort = "^5.11.5" singer-sdk = { version = "^0.42.1", extras = ["testing"] } pylint = "^3.0.0a6" +faker = "^33.1.0" [tool.poetry.extras] s3 = ["fs-s3fs"] diff --git a/scripts/seed.py b/scripts/seed.py new file mode 100644 index 0000000..01fac7b --- /dev/null +++ b/scripts/seed.py @@ -0,0 +1,70 @@ +# /// script +# dependencies = [ +# "faker", +# "pymongo", +# ] +# /// + +import argparse + +import pymongo +from faker import Faker + + +class Params(argparse.Namespace): + host: str + database: str + username: str + password: str + port: int + + +def seed(): + """Seed the database with fake data. + + - users: 100 + - posts: 1000 + """ + parser = argparse.ArgumentParser() + parser.add_argument("--host", default="localhost", help="MongoDB host") + parser.add_argument("--database", required=True, help="MongoDB database") + parser.add_argument("--username", default=None, help="MongoDB username") + parser.add_argument("--password", default=None, help="MongoDB password") + parser.add_argument("--port", default=27017, help="MongoDB port") + args = parser.parse_args(namespace=Params()) + + fake = Faker() + uri = f"mongodb://{args.username}:{args.password}@{args.host}:{args.port}" + client = pymongo.MongoClient(uri) + db = client[args.database] + + users = db["users"] + users.delete_many({}) + users_oids = set() + + for _ in range(100): + result = users.insert_one({ + "name": fake.name(), + "address": fake.address(), + "email": fake.email(), + "joined_at": fake.date_time_this_decade(), + }) + users_oids.add(result.inserted_id) + + posts = db["posts"] + posts.delete_many({}) + for _ in range(1000): + created_at = fake.date_time_this_decade() + updated_at = fake.date_between_dates(created_at) + posts.insert_one({ + "title": fake.sentence(), + "content": fake.text(), + "user_id": fake.random_element(users_oids), + # updated_at is always greater than created_at + "created_at": created_at, + "updated_at": updated_at, + }) + + +if __name__ == "__main__": + seed() From 69e5294488064a73ee9ed2c96a11f63636e3ec00 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Edgar=20Ram=C3=ADrez-Mondrag=C3=B3n?= Date: Tue, 17 Dec 2024 11:09:54 -0600 Subject: [PATCH 4/9] Lint --- scripts/seed.py | 34 +++++++++++++++++++--------------- 1 file changed, 19 insertions(+), 15 deletions(-) diff --git a/scripts/seed.py b/scripts/seed.py index 01fac7b..1952c78 100644 --- a/scripts/seed.py +++ b/scripts/seed.py @@ -21,7 +21,7 @@ class Params(argparse.Namespace): def seed(): """Seed the database with fake data. - + - users: 100 - posts: 1000 """ @@ -43,12 +43,14 @@ def seed(): users_oids = set() for _ in range(100): - result = users.insert_one({ - "name": fake.name(), - "address": fake.address(), - "email": fake.email(), - "joined_at": fake.date_time_this_decade(), - }) + result = users.insert_one( + { + "name": fake.name(), + "address": fake.address(), + "email": fake.email(), + "joined_at": fake.date_time_this_decade(), + } + ) users_oids.add(result.inserted_id) posts = db["posts"] @@ -56,14 +58,16 @@ def seed(): for _ in range(1000): created_at = fake.date_time_this_decade() updated_at = fake.date_between_dates(created_at) - posts.insert_one({ - "title": fake.sentence(), - "content": fake.text(), - "user_id": fake.random_element(users_oids), - # updated_at is always greater than created_at - "created_at": created_at, - "updated_at": updated_at, - }) + posts.insert_one( + { + "title": fake.sentence(), + "content": fake.text(), + "user_id": fake.random_element(users_oids), + # updated_at is always greater than created_at + "created_at": created_at, + "updated_at": updated_at, + } + ) if __name__ == "__main__": From ed0d0320762727e08d9e1e0c71f2d05505abac43 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Edgar=20Ram=C3=ADrez-Mondrag=C3=B3n?= Date: Tue, 17 Dec 2024 11:10:14 -0600 Subject: [PATCH 5/9] Run explicitly as a script --- .github/workflows/validate.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/validate.yml b/.github/workflows/validate.yml index d2deddb..fc0945b 100644 --- a/.github/workflows/validate.yml +++ b/.github/workflows/validate.yml @@ -133,7 +133,7 @@ jobs: run: uv tool install meltano - run: meltano config meltano set venv.backend uv - run: > - uv run seed.py + uv run --script seed.py --host localhost --port 27017 --database ${{ env.DATABASE }} From 03e4a942f3643a8f9960f83c59ad2d3f75821c46 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Edgar=20Ram=C3=ADrez-Mondrag=C3=B3n?= Date: Tue, 17 Dec 2024 11:13:03 -0600 Subject: [PATCH 6/9] Fix script path --- .github/workflows/validate.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/validate.yml b/.github/workflows/validate.yml index fc0945b..fcb28b4 100644 --- a/.github/workflows/validate.yml +++ b/.github/workflows/validate.yml @@ -133,7 +133,7 @@ jobs: run: uv tool install meltano - run: meltano config meltano set venv.backend uv - run: > - uv run --script seed.py + uv run scripts/seed.py --host localhost --port 27017 --database ${{ env.DATABASE }} From be1b05986ac7f0c409011ce4dcc855980a0ec829 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Edgar=20Ram=C3=ADrez-Mondrag=C3=B3n?= Date: Tue, 17 Dec 2024 11:19:01 -0600 Subject: [PATCH 7/9] Test on supported MongoDB versions --- .github/workflows/validate.yml | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/.github/workflows/validate.yml b/.github/workflows/validate.yml index fcb28b4..58bbab5 100644 --- a/.github/workflows/validate.yml +++ b/.github/workflows/validate.yml @@ -71,8 +71,7 @@ jobs: fail-fast: false matrix: mongo-version: - - 3.6 - - 4.4 + - '8.0' python-version: - '3.8' - '3.9' @@ -80,6 +79,11 @@ jobs: - '3.11' - '3.12' - '3.13' + include: + - mongo-version: '6.0' + python-version: '3.13' + - mongo-version: '7.0' + python-version: '3.13' steps: - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 - name: Install poetry @@ -114,6 +118,7 @@ jobs: mongodb-version: - '6.0' - '7.0' + - '8.0' steps: - uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2 - name: Start MongoDB From 92dd28a633b1046274be27ac8b84bac878924bb5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Edgar=20Ram=C3=ADrez-Mondrag=C3=B3n?= Date: Tue, 17 Dec 2024 11:19:06 -0600 Subject: [PATCH 8/9] Lint --- scripts/seed.py | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/scripts/seed.py b/scripts/seed.py index 1952c78..17e0b83 100644 --- a/scripts/seed.py +++ b/scripts/seed.py @@ -5,13 +5,17 @@ # ] # /// +"""Seed the MongoDB database with fake data.""" + import argparse import pymongo from faker import Faker -class Params(argparse.Namespace): +class Params(argparse.Namespace): # pylint: disable=too-few-public-methods + """Namespace for command line arguments.""" + host: str database: str username: str From 00206542b77083dabb6957ec4b4a5041dabda642 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Edgar=20Ram=C3=ADrez-Mondrag=C3=B3n?= Date: Tue, 17 Dec 2024 11:20:20 -0600 Subject: [PATCH 9/9] Fix datetime type --- scripts/seed.py | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/scripts/seed.py b/scripts/seed.py index 17e0b83..c7b6bbf 100644 --- a/scripts/seed.py +++ b/scripts/seed.py @@ -61,13 +61,12 @@ def seed(): posts.delete_many({}) for _ in range(1000): created_at = fake.date_time_this_decade() - updated_at = fake.date_between_dates(created_at) + updated_at = fake.date_time_between_dates(created_at) posts.insert_one( { "title": fake.sentence(), "content": fake.text(), "user_id": fake.random_element(users_oids), - # updated_at is always greater than created_at "created_at": created_at, "updated_at": updated_at, }