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

Max min values #1396

Open
wants to merge 21 commits into
base: development
Choose a base branch
from

Conversation

Rakesh-Ranga-Buram
Copy link
Contributor

Description

This code is related to the create and edit unit changes to incorporate the max and min value checks, and also the changes to make the max and min value associated with the unit to reflect when unit is selected on meter(both create and edit).

Partly Addresses #1307

(In general, OED likes to have at least one issue associated with each pull request. Replace [issue] with the OED GitHub issue number. In the preview you will see an issue description if you hover over that number. You can create one yourself before doing this pull request. This is where details are normally given on what is being addressed. Note you should not use the word "Fixes" if it does not completely address the issue since the issue would automatically be closed on merging the pull request. In that case use "Partly Addresses #[issue].)

Type of change

(Check the ones that apply by placing an "x" instead of the space in the [ ] so it becomes [x])

  • Note merging this changes the database configuration.
  • This change requires a documentation update

Checklist

(Note what you have done by placing an "x" instead of the space in the [ ] so it becomes [x]. It is hoped you do all of them.)

  • I have followed the OED pull request ideas
  • I have removed text in ( ) from the issue request
  • You acknowledge that every person contributing to this work has signed the OED Contributing License Agreement and each author is listed in the Description section.

Limitations

The work related to the trinary changes related to disable checks is still pending

Copy link
Member

@huss huss left a comment

Choose a reason for hiding this comment

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

Thanks to @lawsj, @mmehta2669 & @Rakesh-Ranga-Buram for working on this issue. Review and testing found it generally works but I have made several comments where issues where found. One comment that could not be easily placed into the code was:

src/server/util/compareUnits.js needs to have expectUnitToBeEquivalent updated to test min/max. src/server/test/db/unitTests.js & src/server/test/web/unitsTest.js need to be updated so it properly tests these values (and not just default values for all of them).

Please let me know if anything is not clear or you have thoughts.

min={MIN_VAL}
max={state.maxVal}
defaultValue={state.minVal}
invalid={state?.minVal < MIN_VAL || state?.minVal > state?.maxVal} />
Copy link
Member

Choose a reason for hiding this comment

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

This invalid check conditions should be added to validUnit setting so the save is disabled as done for other checks.

@@ -267,6 +270,34 @@ export default function CreateUnitModalComponent() {
</FormFeedback>
</FormGroup></Col>
</Row>
<Row xs='1' lg='2'>
Copy link
Member

Choose a reason for hiding this comment

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

The min/max exist on create/edit unit pages but not in UnitsDetailComponent.tsx. I think that is fine but the "Edit Unit" button on that page should become "Details/Edit Unit" to mirror meter where it both shows more info and allows editing. I could not put a comment in that file so doing here.

@@ -19,7 +19,7 @@ class Unit {
* @param {*} preferredDisplay True if this unit is always displayed. If not, the user needs to ask to see (for future enhancement).
* @param {*} note Note about this unit.
*/
constructor(id, name, identifier = name, unitRepresent, secInRate = 3600, typeOfUnit, suffix = '', displayable, preferredDisplay, note) {
constructor(id, name, identifier = name, unitRepresent, secInRate = 3600, typeOfUnit, suffix = '', displayable, preferredDisplay, note, minVal, maxVal) {
Copy link
Member

Choose a reason for hiding this comment

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

This changed the signature of the unit constructor. There are a number of places where new Unit(...) is done but was not updated. The value of min/maxVal is undefined in these cases and that is causing issues. For example, I believe that is why a number of tests are failing. The two options are:

  1. Give the two new parameters default values of the min/max on the create page. I think this would be okay in this case.
  2. Change all the calls to have the desired min/max value. This is a little safer but since I think (almost) all cases that would be changed the min/max would not matter the default would be used. Given this, either solution can be used.

I tested doing this and it fixed the failing tests after other fixes applied. On my machine without the change all the tests seem to run so I'm unsure why only 14 ran on GitHub for the PR. Hopefully that will go away but needs to be verified (or addressed if still an issue).

@@ -427,8 +427,8 @@ async function insertMeters(metersToInsert, conn) {
await conn.none(query);
}
const conditionSet = {
minVal: meter.minVal,
maxVal: meter.maxVal,
minVal: minVal,
Copy link
Member

Choose a reason for hiding this comment

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

I'm not sure what this is supposed to be but minVal & maxVal variables are not defined.

@@ -189,8 +189,8 @@ async function uploadReadings(req, res, filepath, conn) {
const mapRowToModel = row => { return row; }; // STUB function to satisfy the parameter of loadCsvInput.

const conditionSet = {
minVal: meter.minVal,
maxVal: meter.maxVal,
minVal: minVal,
Copy link
Member

Choose a reason for hiding this comment

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

See other comment. minVal & maxVal are undefined.

@@ -19,7 +19,7 @@ class Unit {
* @param {*} preferredDisplay True if this unit is always displayed. If not, the user needs to ask to see (for future enhancement).
* @param {*} note Note about this unit.
Copy link
Member

Choose a reason for hiding this comment

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

The JSDoc needs to be updated.

@@ -82,7 +82,9 @@ export const NoUnit: UnitData = {
suffix: '',
displayable: DisplayableType.none,
preferredDisplay: false,
note: ''
note: '',
minVal: -Infinity,
Copy link
Member

Choose a reason for hiding this comment

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

Other places use adminSelectors to get the max/min allowed. I think it makes sense to do that here if possible. My only concern is this is outside a React component but it may work fine since not altering a value.

preferredDisplay: boolean;
note: string;
}
// export interface UnitEditData {
Copy link
Member

Choose a reason for hiding this comment

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

Since this interface seems not to be used it should be removed rather than commented out.

@@ -339,8 +339,8 @@ const LocaleTranslationData = {
"meter.enabled": "Updates:",
"meter.endOnlyTime": "Only End Times:",
"meter.endTimeStamp": "End Time Stamp:",
"meter.minVal": "Minimum Reading Value Check",
"meter.maxVal": "Maximum Reading Value Check",
"minVal": "Minimum Reading Value Check",
Copy link
Member

Choose a reason for hiding this comment

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

This should be placed alphabetically in all languages. Also, it does not follow the key naming conventions. I know the old value was something similar to this but lets use min.value. Similar for max.

@@ -67,6 +67,17 @@ export default function EditMeterModalComponent(props: EditMeterModalComponentPr

const [validMeter, setValidMeter] = useState(isValidMeter(localMeterEdits));

useEffect(() => {
Copy link
Member

Choose a reason for hiding this comment

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

I'm unclear on the relationship of this useEffect and handleUnitChange. They seem to do similar work. I tried commenting this out and it did not seem to matter. It is not in create unit. I may be missing something so let me know.

Also, a comment on what this is doing would be nice. For example, it is getting the min/max reading value from the unit to make that the starting value for the meter when a unit is selected.

@Rakesh-Ranga-Buram
Copy link
Contributor Author

Rakesh-Ranga-Buram commented Dec 27, 2024

@huss, running tests on my local shows some errors and I guess the errors are related to the default_disable_checks on preferences. Should I go ahead and modify that column from boolean to the new enum created?

I think your next comment means this is resolved but let me know if it is not. It is correct that, in general, items that are an enum (or equivalent object in JS) should be matched with an enum in the database so they are equivalent. Also, the newer tests in src/server/test/db/enumTests.js to verify the enum in the database and JS are equivalent should be updated for any new enums added.

@Rakesh-Ranga-Buram
Copy link
Contributor Author

@huss , I added the enum changes on preferences. This seems to be solving the issues I mentioned earlier.

@Rakesh-Ranga-Buram
Copy link
Contributor Author

@huss, running tests on my local shows some errors and I guess the errors are related to the default_disable_checks on preferences. Should I go ahead and modify that column from boolean to the new enum created?

I think your next comment means this is resolved but let me know if it is not. It is correct that, in general, items that are an enum (or equivalent object in JS) should be matched with an enum in the database so they are equivalent. Also, the newer tests in src/server/test/db/enumTests.js to verify the enum in the database and JS are equivalent should be updated for any new enums added.

@huss , yes that is resolved. I will update src/server/test/db/enumTests.js and update this PR shortly

@Rakesh-Ranga-Buram
Copy link
Contributor Author

@huss ,now all the changes have been made

@Rakesh-Ranga-Buram Rakesh-Ranga-Buram marked this pull request as ready for review January 3, 2025 08:11
@Rakesh-Ranga-Buram
Copy link
Contributor Author

@huss , the pipeline changes have been made, Can you please review this PR

@huss
Copy link
Member

huss commented Jan 13, 2025

@huss , the pipeline changes have been made, Can you please review this PR

@Rakesh-Ranga-Buram I went to re-review this PR and noticed that two files have a merge conflict. Will you be resolving that? That will allow the CI to run for the tests.

@Rakesh-Ranga-Buram
Copy link
Contributor Author

@huss , the pipeline changes have been made, Can you please review this PR

@Rakesh-Ranga-Buram I went to re-review this PR and noticed that two files have a merge conflict. Will you be resolving that? That will allow the CI to run for the tests.

@huss ,I have resolved the conflicts and all the tests are passing now

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