mirror of
https://github.com/status-im/sourcecred.git
synced 2025-01-27 04:46:13 +00:00
fd95be68a9
The `DiscourseFetcher` class abstracts over fetching from the Discourse API, and post-processing and filtering the result into a form that's convenient for us. Testing is a bit tricky because the Discourse API keys are sensitive (they are admin keys) and so I'm reluctant to commit them, even for our test instance. As a workaround, I've added a shell script which downloads some data from the SourceCred test instance, and saves it with a filename which is an encoding of the actual endpoint. Then, in testing, we can use a mocked fetch which actually hits the snapshots directory, and thus validate the processing logic on "real" data from the server. We also test that the fetch headers are set correctly, and that we handle non-200 error codes appropriately. Test plan: In addition to the included tests, I have an end-to-end test which actually uses this fetcher to fully populate the mirror and then generate a valid SourceCred graph. This builds on API investigations [here](https://github.com/sourcecred/sourcecred/issues/865#issuecomment-478026449), and is general progress towards #865. Thanks to @erlend-sh, without whom we wouldn't have a test instance.