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

#3275: Slowness on Domain, Domain Info and Domain Requests - [Backup] #3340

Open
wants to merge 23 commits into
base: main
Choose a base branch
from

Conversation

CocoByte
Copy link
Contributor

@CocoByte CocoByte commented Jan 14, 2025

Ticket 3275

Resolves #3275

Changes

  • Revised GenericOrgFilter and FederalTypeFilter to be more efficient
  • Fixtures for DomainRequests was updated to allow us to specify number of entries to load.

Context for reviewers

The admin tables for Domain Requests, Domains, and Domain Information were given a thorough check-up to tease out any remaining opportunities for optimization and to diagnose causes of slow load times.

Findings for root cause of slowness

We already have taken measures to optimize performance of the admin tables, so the cause of slowness this time around was determined to be two filters that were recently added and not optimized for performance -- GenericOrgfilter and FederalTypeFilter. These were added during the course of updating our model structure to use converted fields. However, they were making expensive database calls. They have been revised to be avoid making such calls.

Areas that were verified to be optimized

It is worth noting that the following structures/subroutines were examined and determined to NOT cause slowness. (Code was commented out down to a bare-bones load, then different areas where systematically added back in to see performance impact. Performance was tested for 100000 records. We might want to re-examine some of these areas if we see performance issues with larger data sets)

  • Pagination (This came up alot in the Django admin community as being a cause for performance slowdown, but I did not see any significant slowdown yet for 100000 records)
  • Django's notoriously expensive .count() method (This one came as a surprise for me -- impact on performance was negligible if I disabled the count. We might still want to disable it in the future for very large data sets but I left it alone for now.)
  • Filters other than the two listed above (I inspected each filter for performance impact. Only the two listed above created significant slowdown)
  • Sorting
    • It appears that sorting on non-indexed data isn't having significant negative impact on performance so far. We are doing OK on making sure we add indexes to our models.
    • The custom multisort structure had negligible impact on performance
  • Pre-fetching is in place for foreign key data, so I did not see any obvious places to optimize there.

Setup

  • This might be easiest to test locally, since you need to load the database with large datasets and you need compare performance across both old and new code
  • Load a LOT of data (I used 100000, but smaller values might work, too) into your local database for DomainRequests, Domains, and DomainInformation (for DomainRequests, you can do this by modifying the value of "total_domain_requests_to_make" in the fixture and refreshing your docker OR use whatever other method works for you)

Code Review Verification Steps

Do the following for DomainRequest, Domain, and DomainInformation tables

  • Compare load times of old code with load times of new code on large data sets. (Play around with filters, search, and sorting)
  • Verify that load times on the new code is significantly faster.

As the original developer, I have

Satisfied acceptance criteria and met development standards

  • Met the acceptance criteria, or will meet them in a subsequent PR
  • Created/modified automated tests
  • Update documentation in READMEs and/or onboarding guide

Ensured code standards are met (Original Developer)

  • If any updated dependencies on Pipfile, also update dependencies in requirements.txt.
  • Interactions with external systems are wrapped in try/except
  • Error handling exists for unusual or missing values

Validated user-facing changes (if applicable)

  • Tag @dotgov-designers in this PR's Reviewers for design review. If code is not user-facing, delete design reviewer checklist
  • Verify new pages have been added to .pa11yci file so that they will be tested with our automated accessibility testing
  • Checked keyboard navigability
  • Tested general usability, landmarks, page header structure, and links with a screen reader (such as Voiceover or ANDI)

As a code reviewer, I have

Reviewed, tested, and left feedback about the changes

  • Pulled this branch locally and tested it
  • Verified code meets all checks above. Address any checks that are not satisfied
  • Reviewed this code and left comments. Indicate if comments must be addressed before code is merged
  • Checked that all code is adequately covered by tests
  • Verify migrations are valid and do not conflict with existing migrations

Validated user-facing changes as a developer

Note: Multiple code reviewers can share the checklists above, a second reviewer should not make a duplicate checklist. All checks should be checked before approving, even those labeled N/A.

  • New pages have been added to .pa11yci file so that they will be tested with our automated accessibility testing
  • Checked keyboard navigability
  • Meets all designs and user flows provided by design/product
  • Tested general usability, landmarks, page header structure, and links with a screen reader (such as Voiceover or ANDI)
  • (Rarely needed) Tested as both an analyst and applicant user

As a designer reviewer, I have

Verified that the changes match the design intention

  • Checked that the design translated visually
  • Checked behavior. Comment any found issues or broken flows.
  • Checked different states (empty, one, some, error)
  • Checked for landmarks, page heading structure, and links

Validated user-facing changes as a designer

  • Checked keyboard navigability
  • Tested general usability, landmarks, page header structure, and links with a screen reader (such as Voiceover or ANDI)
  • Tested with multiple browsers (check off which ones were used)
    • Chrome
    • Microsoft Edge
    • FireFox
    • Safari
  • (Rarely needed) Tested as both an analyst and applicant user

References

Screenshots

@CocoByte CocoByte requested a review from abroddrick as a code owner January 14, 2025 02:54
@CocoByte CocoByte changed the title #3275: Slowness on Domain, Domain Info and Domain Requests [DRAFT - fixing tests] #3275: Slowness on Domain, Domain Info and Domain Requests Jan 14, 2025
Copy link

🥳 Successfully deployed to developer sandbox nl.

Copy link

🥳 Successfully deployed to developer sandbox nl.

Copy link

🥳 Successfully deployed to developer sandbox nl.

@@ -779,7 +779,8 @@ def test_short_org_name_in_domains_list(self):
response = self.client.get("/admin/registrar/domain/")
# There are 4 template references to Federal (4) plus four references in the table
# for our actual domain_request
self.assertContains(response, "Federal", count=57)
self.assertContains(response, "Federal", count=54)
self.assertContains(response, "federal", count=225)
Copy link
Contributor Author

Choose a reason for hiding this comment

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

The updates to the filters means we no longer grab display values for Federal Type or Generic org type. It's a small sacrifice that needs to be reflected in the unit tests, which check for camel case.

@CocoByte CocoByte changed the title [DRAFT - fixing tests] #3275: Slowness on Domain, Domain Info and Domain Requests #3275: Slowness on Domain, Domain Info and Domain Requests - [NL] Jan 15, 2025
Copy link

🥳 Successfully deployed to developer sandbox nl.

Copy link

🥳 Successfully deployed to developer sandbox nl.

@asaki222 asaki222 self-assigned this Jan 15, 2025
Copy link

🥳 Successfully deployed to developer sandbox nl.

Copy link

🥳 Successfully deployed to developer sandbox nl.

Copy link
Contributor

@asaki222 asaki222 left a comment

Choose a reason for hiding this comment

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

I think this looks good overall. Just had a couple questions.

On the sandbox, I got a 500 error when I hit federal type on the domain admin table, but generic org type works.

I don't see the federal type filter on the right on the Domain Request table on the sandbox.

src/registrar/admin.py Outdated Show resolved Hide resolved
src/registrar/admin.py Outdated Show resolved Hide resolved
@CocoByte CocoByte changed the title #3275: Slowness on Domain, Domain Info and Domain Requests - [NL] #3275: Slowness on Domain, Domain Info and Domain Requests - [Backup] Jan 16, 2025
Copy link

🥳 Successfully deployed to developer sandbox nl.

@CocoByte CocoByte requested a review from asaki222 January 17, 2025 22:57
Copy link

🥳 Successfully deployed to developer sandbox nl.

Copy link

🥳 Successfully deployed to developer sandbox nl.

@zandercymatics zandercymatics self-assigned this Jan 21, 2025
Copy link

🥳 Successfully deployed to developer sandbox nl.

Copy link
Contributor

@zandercymatics zandercymatics left a comment

Choose a reason for hiding this comment

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

More will come soon! Just need to run the code

src/registrar/fixtures/fixtures_requests.py Outdated Show resolved Hide resolved
src/registrar/fixtures/fixtures_requests.py Show resolved Hide resolved
Copy link
Contributor

@zandercymatics zandercymatics left a comment

Choose a reason for hiding this comment

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

Nice work, seems a lot faster.

My two blocks are just regarding the usage of def lookup but they are relatively minor things. Lookups is returning the value of each org choice option, but the fix for that is easy and should not impact performance at all. After those are fixed - I am happy to approve!

src/registrar/admin.py Show resolved Hide resolved
src/registrar/admin.py Outdated Show resolved Hide resolved
Copy link

🥳 Successfully deployed to developer sandbox nl.

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.

Slowness on Domain, Domain Info and Domain Requests
3 participants