Skip to content

qxf2/newsletter_automation

Repository files navigation

Newsletter automation

This project is to automate the process of creating the weekly Qxf2 newsletter. We take the URLs posted on the Skype channel as input and create a MailChimp campaign.

Run the project locally using Docker

  1. Clone the repository

  2. Run
    docker build --tag $TAG .
    docker run -it -p 5000:5000 $TAG

At this point, you are ready to run the app locally.

  1. To test that your setup works, please visit http://localhost:5000 and login. Then, try to add a single article via the form in the /articles page.

Add articles through api endpoint

To add articles using POST method use the following:

  1. Set your api key in environment variable as 'API_KEY': '<YOURAPIKEY>'
  2. Use the same api key for Request headers 'x-api-key': '<YOURAPIKEY>'
  3. API Endpoint: POST <base_url>/api/articles
  4. Example curl command curl -X POST http://localhost:5000/api/articles -H 'X-API-KEY: <YOUR_API_KEY>' -F 'url=http://exampleURL.com' -F 'category_id=2

How to run Great Expectations test locally:

Great Expectations is an open-source Python library to test data pipelines. It helps in validating and documenting data and thus maintaining data quality.

  1. Install great_expectations: pip install great_expectations

  2. Set the environment variables prefixed with DB_, mentioned in great_expectations.yml

  3. Navigate to tests > data_validation > great_expectations directory: cd tests/data_validation/great_expectations

  4. Run the checkpoint script. Navigate to newsletter_automation directory and run:

    pytest tests/data_validation/great_expectations/utils/ -s -v -m checkpoint10am

    This will trigger the Checkpoint and run the Expectation Suite against the MySQL table data as configured in the datasource. Please use the correct pytest marker to trigger the relevant checkpoint.

  5. Results are stored in great_expectations/uncommitted/data_docs/local_site folder. Navigate to the above directory using File Explorer. Open index.html, go to Validations tab and select your recent run. It will show details of what expectations have run, how many have passed/failed, failure details etc.

About

Automate the generation of Qxf2 newsletter

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published