-
Notifications
You must be signed in to change notification settings - Fork 22
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
Add couple of sanity checks, improve e2e test usability and fix minor bugs #43
Conversation
@@ -55,34 +55,34 @@ typeOf: dcid:City | |||
Node: dcid:CH-SH | |||
dcid: "CH-SH" | |||
name: "Shanghai" | |||
location: | |||
location: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just noticing... filed #44 for this
TestUtil.readStringFromPath(expectedReportPath), | ||
TestUtil.readStringFromPath(actualReportPath)); | ||
assertEquals( | ||
org.datacommons.util.TestUtil.mcfFromFile(expectedGeneratedFilePath.toString()), |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
is just using TestUtil sufficient (rather than the full package path?)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There's a TestUtil in this directory too.
actualLog.getCounterSet().getCountersMap()); | ||
assertMapsAreEqual( | ||
"Level Summary", expectedLog.getLevelSummaryMap(), actualLog.getLevelSummaryMap()); | ||
assertTrue(actualLog.getEntriesList().containsAll(expectedLog.getEntriesList())); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
have you tried this pattern? it might give better error messages (there's also an option to ignore ordering).
assertThat(actualRecordProtos)
.displayingDiffsPairedBy(Record::getId)
.containsExactlyElementsIn(expectedRecords);
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That is an awesome tip! Though I didn't use this specifically, I finally found a way to do "expect" and got rid of the custom function.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
thanks for the changes!
@@ -33,15 +33,24 @@ | |||
// directory, add an input directory and an output directory. In the input directory, put the test | |||
// files you want to run the lint tool against. In the output directory, put a report.json file with | |||
// the expected report output. | |||
// | |||
// These tests can be run in a mode to produce golden files, as below: | |||
// mvn -DgoldenFilesPrefix=$PWD/tool/src/test/resources/org/datacommons/tool test |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
should there be a space like "mvn -D goldenFilesPrefix..."?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@@ -38,6 +40,14 @@ | |||
Set.of(Vocabulary.DOMAIN_INCLUDES, Vocabulary.RANGE_INCLUDES); | |||
private final Set<String> PROP_REFS_IN_PROP = | |||
Set.of(Vocabulary.NAME, Vocabulary.LABEL, Vocabulary.DCID, Vocabulary.SUB_PROPERTY_OF); | |||
|
|||
// Includes: a-z A-Z 0-9 _ & + - % / . )( |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
do we want to allow "&" in dcid? When I did an import, I noticed that enums that represent a combination of multiple enums uses "&" to concat the multiple enums and so having "&" in a dcid gave me problems.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
i believe we already include "&", but i was hoping we can avoid any special url characters from our dcid's (so no [&?= #]%+
). we do use /
but are able to handle this on the clients
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Unfortunately, &+%
show up currently in our refs/dcids today.
I've filed #45 to track this. Perhaps we could disallow in import tool with a special mode to run backward-compatibly, or something?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
since this is long-pending/important, lets switch discussion to #45, and I'll submit this PR :)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for the review!
TestUtil.readStringFromPath(expectedReportPath), | ||
TestUtil.readStringFromPath(actualReportPath)); | ||
assertEquals( | ||
org.datacommons.util.TestUtil.mcfFromFile(expectedGeneratedFilePath.toString()), |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There's a TestUtil in this directory too.
@@ -33,15 +33,24 @@ | |||
// directory, add an input directory and an output directory. In the input directory, put the test | |||
// files you want to run the lint tool against. In the output directory, put a report.json file with | |||
// the expected report output. | |||
// | |||
// These tests can be run in a mode to produce golden files, as below: | |||
// mvn -DgoldenFilesPrefix=$PWD/tool/src/test/resources/org/datacommons/tool test |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
actualLog.getCounterSet().getCountersMap()); | ||
assertMapsAreEqual( | ||
"Level Summary", expectedLog.getLevelSummaryMap(), actualLog.getLevelSummaryMap()); | ||
assertTrue(actualLog.getEntriesList().containsAll(expectedLog.getEntriesList())); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That is an awesome tip! Though I didn't use this specifically, I finally found a way to do "expect" and got rid of the custom function.
@@ -38,6 +40,14 @@ | |||
Set.of(Vocabulary.DOMAIN_INCLUDES, Vocabulary.RANGE_INCLUDES); | |||
private final Set<String> PROP_REFS_IN_PROP = | |||
Set.of(Vocabulary.NAME, Vocabulary.LABEL, Vocabulary.DCID, Vocabulary.SUB_PROPERTY_OF); | |||
|
|||
// Includes: a-z A-Z 0-9 _ & + - % / . )( |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Unfortunately, &+%
show up currently in our refs/dcids today.
I've filed #45 to track this. Perhaps we could disallow in import tool with a special mode to run backward-compatibly, or something?
New checks:
(Some of the above should also address #36, though existence-checks would already report errors, in a round-about way.)
While rolling this out, found it very hard to update the expectation for the e2e tests, so made two changes:
Fix a couple of bugs in parser:
StringUtil.SplitStructuredLineWithEscapes
returns failure, we shouldn't throw exception. (See added McfParserTest unit tests)