-
Notifications
You must be signed in to change notification settings - Fork 23
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Browse files
Browse the repository at this point in the history
* remove upstream * introducing penalty metachecks * Added penalty meta test exectution step * added penalty meta tests to final output writer * added logging for penalty metatest * fixed equals in exec step * suitable Result constructor in testutils * Penalty MetaTests integration Tests _1 * Update README with penalty meta tests description * More tests on PenaltyMetaTests * Increase consistency in writing the result * improve conditions about displaying metatests and codechecks results * Standard result writer tests * penalty meta tests in Weblab result writer * Remove unnecessary import * Fix logic bug * Revert "Increase consistency in writing the result" This reverts commit bc24b9c. * Revert output format changes --------- Co-authored-by: puctom <[email protected]> Co-authored-by: Martin Mladenov <[email protected]>
- Loading branch information
1 parent
9a35d34
commit fec659f
Showing
18 changed files
with
710 additions
and
15 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
62 changes: 62 additions & 0 deletions
62
andy/src/main/java/nl/tudelft/cse1110/andy/execution/step/RunPenaltyMetaTestsStep.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,62 @@ | ||
package nl.tudelft.cse1110.andy.execution.step; | ||
|
||
import nl.tudelft.cse1110.andy.config.DirectoryConfiguration; | ||
import nl.tudelft.cse1110.andy.config.MetaTest; | ||
import nl.tudelft.cse1110.andy.config.RunConfiguration; | ||
import nl.tudelft.cse1110.andy.execution.Context.Context; | ||
import nl.tudelft.cse1110.andy.execution.ExecutionStep; | ||
import nl.tudelft.cse1110.andy.result.MetaTestResult; | ||
import nl.tudelft.cse1110.andy.result.ResultBuilder; | ||
|
||
import java.util.ArrayList; | ||
import java.util.List; | ||
|
||
public class RunPenaltyMetaTestsStep implements ExecutionStep { | ||
|
||
@Override | ||
public void execute(Context ctx, ResultBuilder result) { | ||
DirectoryConfiguration dirCfg = ctx.getDirectoryConfiguration(); | ||
RunConfiguration runCfg = ctx.getRunConfiguration(); | ||
|
||
int score = 0; | ||
int totalWeight = 0; | ||
|
||
ClassLoader currentClassLoader = Thread.currentThread().getContextClassLoader(); | ||
|
||
try { | ||
|
||
List<MetaTest> metaTests = runCfg.penaltyMetaTests(); | ||
List<MetaTestResult> metaTestResults = new ArrayList<>(); | ||
|
||
for (MetaTest metaTest : metaTests) { | ||
|
||
boolean passesTheMetaTest = metaTest.execute(ctx, dirCfg, runCfg); | ||
|
||
if (passesTheMetaTest) { | ||
score += metaTest.getWeight(); | ||
} | ||
|
||
metaTestResults.add(new MetaTestResult(metaTest.getName(), metaTest.getWeight(), passesTheMetaTest)); | ||
|
||
totalWeight += metaTest.getWeight(); | ||
} | ||
|
||
result.logPenaltyMetaTests(score, totalWeight, metaTestResults); | ||
} catch (Exception ex) { | ||
result.genericFailure(this, ex); | ||
} finally { | ||
/* restore the class loader to the one before meta tests */ | ||
Thread.currentThread().setContextClassLoader(currentClassLoader); | ||
} | ||
} | ||
|
||
@Override | ||
public boolean equals(Object other) { | ||
return other instanceof RunPenaltyMetaTestsStep; | ||
} | ||
|
||
@Override | ||
public int hashCode() { | ||
return super.hashCode(); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.