diff --git a/src/cellType.ts b/src/cellType.ts index 29ac660..0b3734f 100644 --- a/src/cellType.ts +++ b/src/cellType.ts @@ -11,7 +11,7 @@ import { cellControls as cellControlsTemplate, icons } from "starboard-notebook/ import { NBGraderMetadata, StarboardGraderMetadata } from "./types"; import { graderMetadataToNBGraderCellType } from "./graderUtils"; import { TemplateResult } from "lit-html"; -import { CodeRunnerFeedbackElement } from "./elements/codeRunnerFeedback"; +import { CodeRunnerFeedbackElement, CodeRunnerResult } from "./elements/codeRunnerFeedback"; declare const runtime: Runtime declare const html: typeof lithtml.html; @@ -226,7 +226,6 @@ export class GraderCellHandler implements CellHandler { attach(params: CellHandlerAttachParameters) { this.elements = params.elements; - this.setupEditor(); this.updateRender(); } @@ -244,9 +243,11 @@ export class GraderCellHandler implements CellHandler { this.lastRunId++; const currentRunId = this.lastRunId; this.isCurrentlyRunning = true; + this.codeRunnerFeedbackElement.setRunResult("running"); if (pythonPlugin.getPyodideLoadingStatus() !== "ready") { this.isCurrentlyLoadingPyodide = true; + this.codeRunnerFeedbackElement.setRunResult("running-setup"); lithtml.render(this.getControls(), this.elements.topControlsElement); } @@ -257,12 +258,17 @@ export class GraderCellHandler implements CellHandler { } catch(e) { didError = true; } + this.isCurrentlyLoadingPyodide = false; if (this.lastRunId === currentRunId) { this.isCurrentlyRunning = false; lithtml.render(this.getControls(), this.elements.topControlsElement); - this.codeRunnerFeedbackElement.setRunResult(didError ? "fail" : "success"); + let runnerStatusCode: CodeRunnerResult = didError ? "fail" : "success"; + if (this.graderType === "autograder-tests") { + runnerStatusCode = didError ? "test-fail" : "test-success"; + } + this.codeRunnerFeedbackElement.setRunResult(runnerStatusCode); } return val; diff --git a/src/elements/codeRunnerFeedback.ts b/src/elements/codeRunnerFeedback.ts index 571afda..33d8b54 100644 --- a/src/elements/codeRunnerFeedback.ts +++ b/src/elements/codeRunnerFeedback.ts @@ -1,6 +1,6 @@ import {LitElement, LitHtml} from "starboard-notebook/dist/src/runtime/esm/exports/libraries"; -export type CodeRunnerResult = "empty" | "success" | "fail"; +export type CodeRunnerResult = "empty" | "success" | "test-success" | "test-fail" | "fail" | "running" | "running-setup"; const html = LitHtml.html; @@ -37,37 +37,48 @@ export class CodeRunnerFeedbackElement extends LitElement.LitElement { render() { return html` - ${this.result === "empty" ? undefined : html`
${ - this.result === "success" ? - html`
- ✅ Code ran succesfully -
`: - html`
- ❌ An exception was thrown (tests failed) -
` + (() => { + switch(this.result) { + case("success"): { + return html`
+ ✅ Code ran succesfully +
` + } + case("fail"): { + return html`
+ ❌ An error was thrown +
` + } + case("test-success"): { + return html`
+ ✅ Tests passed +
` + } + case("test-fail"): { + return html`
+ ❌ Tests failed. +
` + } + case("running"): { + return html`
+ ⚙️ Cell is running.. +
` + } + case("running-setup"): { + return html`
+ ⚙️ Cell is running.. (for the first time, setup will take some extra time) +
` + } + } + + })() }
` }
` } -} \ No newline at end of file +} diff --git a/src/styles.css b/src/styles.css index c2e0e9d..9850ce6 100644 --- a/src/styles.css +++ b/src/styles.css @@ -9,3 +9,24 @@ border-bottom-right-radius: 0; border-bottom: 1px transparent solid; } + +.grader-code-feedback-bar { + border: 1px solid #999; + background-color: #fafafa; + padding: 0.2em 0.4em; + font-size: 0.75em; +} +.grader-code-feedback-bar.success, .grader-code-feedback-bar.test-success{ + border: 1px solid #00ce6e; + background-color: #baedc0; +} + +.grader-code-feedback-bar.fail, .grader-code-feedback-bar.test-fail { + border: 1px solid #d20d0d; + background-color: #eba0ac; +} + +.grader-code-feedback-bar.running, .grader-code-feedback-bar.running-setup { + border: 1px solid #9ad0ff; + background-color: #e4f6ff; +} \ No newline at end of file