diff options
author | 2022-06-18 02:31:30 +0400 | |
---|---|---|
committer | 2022-06-18 02:31:30 +0400 | |
commit | f1abb728ae99254ebc695720d61b63896c0cc26a (patch) | |
tree | f0653e47bd7cadbeb8455c98dcd3aa8d05d1e11c /src/components | |
parent | Merge pull request #447 from python-discord/dependabot/npm_and_yarn/webpack-5... (diff) | |
parent | Merge branch 'main' into snekbox-results-feedback (diff) |
Merge pull request #453 from DavinderJolly/snekbox-results-feedback
Fix rendering error message for failed unit tests.
Diffstat (limited to 'src/components')
-rw-r--r-- | src/components/Question.tsx | 15 |
1 files changed, 13 insertions, 2 deletions
diff --git a/src/components/Question.tsx b/src/components/Question.tsx index 2914ae6..ebacb4a 100644 --- a/src/components/Question.tsx +++ b/src/components/Question.tsx @@ -37,6 +37,9 @@ class RenderedQuestion extends React.Component<QuestionProp> { this.setPublicState("valid", true); this.setPublicState("error", ""); + if (props.question.type === QuestionType.Code) { + this.setPublicState("unittestsFailed", false); + } if (!skip_normal_state.includes(props.question.type)) { this.setPublicState("value", ""); @@ -44,8 +47,8 @@ class RenderedQuestion extends React.Component<QuestionProp> { } setPublicState(target: string, value: string | boolean | null, callback?:() => void): void { - this.setState({[target]: value}, callback); this.props.public_state.set(target, value); + this.setState({[target]: value}, callback); } // This is here to allow dynamic selection between the general handler, textarea, and code field handlers. @@ -155,6 +158,7 @@ class RenderedQuestion extends React.Component<QuestionProp> { } let invalid = false; + let unittest_failed = false; const options: string | string[] = this.props.question.data["options"]; switch (this.props.question.type) { case QuestionType.TextArea: @@ -163,6 +167,9 @@ class RenderedQuestion extends React.Component<QuestionProp> { if (this.props.public_state.get("value") === "") { invalid = true; } + if (this.props.public_state.get("unittestsFailed")) { + unittest_failed = true; + } break; case QuestionType.Select: @@ -189,7 +196,11 @@ class RenderedQuestion extends React.Component<QuestionProp> { if (invalid) { this.setPublicState("error", "Field must be filled."); this.setPublicState("valid", false); - } else { + } else if (unittest_failed) { + this.setPublicState("error", "1 or more unittests failed."); + this.setPublicState("valid", false); + } + else { this.setPublicState("error", ""); this.setPublicState("valid", true); } |