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

Simplify review process #135

Merged
merged 23 commits into from
Nov 20, 2024
Merged

Simplify review process #135

merged 23 commits into from
Nov 20, 2024

Conversation

jthompson-arcus
Copy link
Collaborator

Addresses part of #113. Follows PR #115.

@jthompson-arcus jthompson-arcus changed the base branch from dev to jt-113-logging_tables November 8, 2024 15:36
@jthompson-arcus
Copy link
Collaborator Author

This PR has two goals:

  1. Convince ourselves that db_slice_rows() is not needed to review forms any more.
  2. Remove db_slice_rows() from the review process.

@jthompson-arcus jthompson-arcus changed the base branch from jt-113-logging_tables to dev November 8, 2024 15:52
@jthompson-arcus jthompson-arcus changed the base branch from dev to jt-113-logging_tables November 8, 2024 15:52
@jthompson-arcus jthompson-arcus mentioned this pull request Nov 11, 2024
6 tasks
Base automatically changed from jt-113-logging_tables to dev November 11, 2024 17:56
@jthompson-arcus jthompson-arcus marked this pull request as ready for review November 11, 2024 19:16
@jthompson-arcus
Copy link
Collaborator Author

@LDSamson WRT our discussion about whether the ID field can be updated, It was indirectly captured via a snapshot that the ID did not get updated here. I have also added a trigger to this PR that will literally cause a failure if that field is attempted to be updated.

R/fct_SQLite.R Outdated
Comment on lines 167 to 176
# This will trigger before any UPDATEs happen on all_review_data. Instead of
# allowing 'id' to be updated, it will throw an error.
rs <- DBI::dbSendStatement(con, paste(
"CREATE TRIGGER all_review_data_id_update_trigger",
"BEFORE UPDATE OF id ON all_review_data",
"BEGIN",
"SELECT RAISE(FAIL, 'all_review_data.id is read only');",
"END"
))
DBI::dbClearResult(rs)
Copy link
Collaborator

Choose a reason for hiding this comment

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

I tried to test this behavior with a test database. Could it be that these are not updated yet? Also, is it possible to capture this in a test? It is quite important that this does not go wrong.

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

Should this behavior be extended to all idx_cols?

Copy link
Collaborator

Choose a reason for hiding this comment

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

Good question. I feel like the id column is the most important since it links the review data to the audit/log table.

I am trying to thing if there would be a moment that one of the idx_cols/common_vars gets updated.
What would happen if this occurs for the event_name (e.g. from visit 1 to visit 2, although I think that would be rare)? Would that count as a completely new row with a new id?

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

Well with the construction as it stands now (and how it functioned previously I believe) this would get input to the review data base as a new record and a warning would be triggered indicating "items were not found in the updated dataset". See update_review_data().

R/fct_db_collect_data.R Outdated Show resolved Hide resolved
R/run_app.R Outdated Show resolved Hide resolved
R/fct_SQLite.R Outdated Show resolved Hide resolved
dplyr::collect()
if(nrow(new_review_rows) == 0){return(
warning("Review state unaltered. No review will be saved.")
)}
new_review_rows <- new_review_rows |>
db_slice_rows(slice_vars = c("timestamp", "edit_date_time"), group_vars = common_vars) |>
Copy link
Collaborator

Choose a reason for hiding this comment

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

Note that this is the only place where we are using the common_vars; maybe the function argument is then not needed anymore?

Also, for the SQL statement below: what happens if, for example, row 20 is saved by someone else previously and then the entire form will be saved by me. Will the name of the reviewer of row 20 be my name or still from the other person?

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

The tests you added in #134 are important in capturing this behavior. I may go ahead and add them to this PR so that behavior is more clearly captured and shown in the tests.

Copy link
Collaborator

@LDSamson LDSamson left a comment

Choose a reason for hiding this comment

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

@jthompson-arcus I have a few comments, see below.

@jthompson-arcus
Copy link
Collaborator Author

@LDSamson let me know what you think of these changes. I think adding a test could be good but will need to rework db_add_primary_key() and db_add_log() to not be so all_review_data focused.

@LDSamson
Copy link
Collaborator

@jthompson-arcus I think it looks okay as far as I can see but it is a bit difficult to see the differences between the changes I made (in the currently open PR on main) and this one, for the tests. I will have a closer look tomorrow.

@jthompson-arcus
Copy link
Collaborator Author

@jthompson-arcus I think it looks okay as far as I can see but it is a bit difficult to see the differences between the changes I made (in the currently open PR on main) and this one, for the tests. I will have a closer look tomorrow.

@LDSamson I copied from and compared to #134. Only difference I could tell was ordering.

Copy link
Collaborator

@LDSamson LDSamson left a comment

Choose a reason for hiding this comment

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

@LDSamson let me know what you think of these changes. I think adding a test could be good but will need to rework db_add_primary_key() and db_add_log() to not be so all_review_data focused.

It would be great to add tests indeed since this is a vital part of functioning of the application. But it looks good and the tests can be added in a follow-up PR, it all looks like it is working as intended now.

Note that I added some minor changes, mainly to adhere better to the tidyverse style guide.

@LDSamson LDSamson merged commit 740a10a into dev Nov 20, 2024
3 checks passed
@LDSamson LDSamson deleted the jt-113-simplify_review_process branch November 20, 2024 11:39
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.

2 participants