Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Staging update #174

Open
wants to merge 97 commits into
base: master
Choose a base branch
from
Open

Staging update #174

wants to merge 97 commits into from

Conversation

adamtry
Copy link
Contributor

@adamtry adamtry commented Apr 1, 2025

FaisalHackney and others added 30 commits July 24, 2024 11:12
* Remove useless launchsettings

* Delete current test database folder

* Upgrade test SDK

* Add HFSDatabaseObjects submodule

* Use submodule remote db makefile
Tests for this process, rewritten in Entity Framework.

Runs on the EE Docker environment (make unit_db_ee)

See sproc code: https://github.com/LBHackney-IT/HFSDatabaseObjects/blob/880959d860c087cde6f946f16834e8f5b2416c0a/stored_procedures/usp_LoadCashFile.sql

What the stored procedure does is:

    Clears UPCashDump records associated with filenames that were unsuccessfully processed
    For the rest of the UPCashDump records that are unread, parses their FullText into various fields
    Inserts the parsed data into UPCashLoad
    Marks the processed UPCashDump records as read

Other changes:

    Switch the DatabaseContext tests to use the Dockerised SQL Server database from the HFSDatabaseObjects module added in 

Add HFSDatabaseObjects submodule for unit test database #148
Added a helper class + methods to clear tables in reverse dependency order automatically. This can become a major headache if it needs to be done manually on each test, especially as the nesting grows larger.
Fixed some database entities to ensure EF can create them from fixtures without errors.
Cleared up redundant entries in the docker-compose.yml as part of preparation for using it to support running these tests in future
Speed up the HFS reports use case tests from ~15 minutes running time to ~1 minute by allowing file wait and retry durations to be modified.

This cuts down the CI pipeline duration to ~2.5 minutes, as the reports UC tests were the bottleneck. The reports UC made use of hard time waits and retry intervals which ran far longer than is needed in unit tests that aren't connected to real infrastructure.

This PR modifies the GenerateReportUseCase to take in optional sleepDuration and retryInterval params that retain the original values as defaults, but can be overridden in the tests or elsewhere in the application as needed. It also ensures the UC reports are generated and checked using a retry mechanism and a timeout similar to how it was already done in one of the reports, instead of just hard wait duration.

Time calculations in the tests often assumed the default values for sleep and retry durations, so they have been modified accordingly.

Tests for this stored procedure
Runs on the EE Docker environment (make unit_db_ee)

See sproc code: https://github.com/LBHackney-IT/HFSDatabaseObjects/blob/880959d860c087cde6f946f16834e8f5b2416c0a/stored_procedures/usp_GetCashImportByDate.sql

What the stored procedure does is:

    Takes in a startDate and endDate as parameters
    Gets CashDump records, parsing the date from the filename
    Using all suspense and non-suspense SSMiniTransaction records, creates a summed total transaction amount by rent group, and grand total

Note:

    There are many assorted cases that could cause records to not be selected as part of the report, however these cases tend to be fairly trivial and still verbose to test effectively. I believe that only the happy path is worth testing for this process at this time.
Update Tenancy Agreement Details Endpoint
humulla and others added 26 commits December 5, 2024 12:45
This change resolves a build failure because Serverless Framework 4 doesn't pick up globally installed modules. I'm not sure why this has changed (or how/if it's actually changed), but it's sensible to version the dependencies and installing the plugin using 'npm install' following the docs _also_ allows the command to succeed.
save changes made to ispresent and isterminated
In #162
I introduced `package.json` to manage Serverless plugins (because it's
recommended by the docs and the existing approach failed in CI), however
I failed to do two things:

1. Actually install Serverless 4. The change was _supposed_ to switch
   from using `npm install -g serverless@3` followed by executing `sls`
   to a single use of `npx --yes serverless deploy`. In #162 I removed
   the global install step but didn't update how we called serverless
   🤦.

2. Removing the plugin install steps, so it attempted to install them
   twice 🤦.

So, double facepalm. Sorry!

This change resolves those two errors.
In #163 we upgraded
.Net from 6 to 8, but missed one reference in the CircleCI config, which caused the build to fail.

This change fixes that.
🤦 Update all .Net refs to 8.0
* Update staging lambda authorizer

* Update dev auth arn

---------

Co-authored-by: Adam <[email protected]>
@adamtry adamtry changed the title Update production authorizer ARN Staging update Apr 1, 2025
Copy link
Contributor

@Duslerke Duslerke left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Not ready yet due to ongoing EOY monitoring.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants