From fb00efbbb94b722f767f569c4483712a74c9f29d Mon Sep 17 00:00:00 2001 From: Candace Savonen Date: Fri, 10 Jan 2025 15:54:06 -0500 Subject: [PATCH 1/3] Functionalize quiz check --- NAMESPACE | 1 + R/quiz_formatting.R | 82 ++++++++++++++++++++++++++++++++++- man/check_quiz_dir.Rd | 51 ++++++++++++++++++++++ tests/testthat/test-quizzes.R | 21 +++++++++ 4 files changed, 154 insertions(+), 1 deletion(-) create mode 100644 man/check_quiz_dir.Rd diff --git a/NAMESPACE b/NAMESPACE index ebfba0f..3567835 100644 --- a/NAMESPACE +++ b/NAMESPACE @@ -9,6 +9,7 @@ export(check_git_repo) export(check_question) export(check_quiz) export(check_quiz_attributes) +export(check_quiz_dir) export(check_quiz_question_attributes) export(check_quizzes) export(check_spelling) diff --git a/R/quiz_formatting.R b/R/quiz_formatting.R index be92dd5..635fe8c 100644 --- a/R/quiz_formatting.R +++ b/R/quiz_formatting.R @@ -1,8 +1,88 @@ -# C. Savonen 2021 +# C. Savonen 2025 utils::globalVariables(c("question", "original", "n", "metadata_check", "index", "ignore_coursera")) +#' Check all quizzes' formatting for Leanpub +#' +#' @param path path to the bookdown or quarto course repository, must have a +#' `.github` folder which will be used to establish the top of the repo. +#' @param quiz A relative file path to the folder (existing or not) that contains the quizzes +#' in Leanpub format. Default is "quizzes". +#' @param output_dir A relative file path to the folder (existing or not) that the +#' output check file should be saved to. Default is "check_reports" +#' @param resources_dir A relative file path to the folder (existing or not) that the +#' ignore_urls.txt file and exclude_files.txt will be found. Default is "resources". +#' If no ignore_urls.txt file and exclude_files.txt files are found, we will download one. +#' @param report_all Should all URLs that were tested be returned? Default is FALSE +#' meaning only broken URLs will be reported in the url_checks.tsv file. +#' @return A file will be saved that lists the broken URLs will be saved to the specified output_dir. +#' @export +#' +#' @importFrom magrittr %>% +#' @importFrom rprojroot find_root has_dir +#' @importFrom tidyr unnest separate +#' @importFrom readr write_tsv +#' +#' @examples \dontrun{ +#' +#' rmd_dir <- setup_ottr_template(dir = ".", type = "rmd", render = FALSE) +#' +#' check_quiz_dir(rmd_dir) +#' +#' # If there are broken URLs they will be printed in a list at 'question_error_report.tsv' +#' +#' qmd_dir <- setup_ottr_template(dir = ".", type = "quarto", render = FALSE) +#' +#' check_quiz_dir(qmd_dir) +#' } +check_quiz_dir <- function(path = ".", + quiz_dir = "quizzes", + output_dir = "check_reports", + resources_dir = "resources", + report_all = FALSE) { + # Find .git root directory + root_dir <- rprojroot::find_root(path = path, rprojroot::has_dir(".github")) + + resources_dir <- file.path(root_dir, resources_dir) + output_dir <- file.path(root_dir, output_dir) + + if (!dir.exists(output_dir)) { + dir.create(output_dir, recursive = TRUE, showWarnings = FALSE) + } + if (!dir.exists(resources_dir)) { + dir.create(resources_dir, recursive = TRUE, showWarnings = FALSE) + } + + output_file <- file.path(output_dir, 'question_error_report.tsv') + ignore_urls_file <- file.path(resources_dir, "ignore-urls.txt") + exclude_file <- file.path(resources_dir, "exclude_files.txt") + + ottrpal::check_quizzes(quiz_dir = file.path(root_dir, quiz_dir), write_report = TRUE, verbose = TRUE) + + if (file.exists("question_error_report.tsv")) { + quiz_errors <- readr::read_tsv("question_error_report.tsv") + + file.copy('question_error_report.tsv', file.path(root_dir, 'check_reports')) + file.remove('question_error_report.tsv') + + # Print out how many quiz check errors + write(nrow(quiz_errors), stdout()) + + } else { + quiz_errors <- data.frame() + + # Print out how many quiz check errors + write("1", stdout()) + } + + # Save question errors to file + readr::write_tsv(quiz_errors, output_file) + + message(paste0("Saved to: ", output_file)) +} + + find_end_of_prompt <- function(start_prompt_index, type_vector) { # We want to see if the next line is where the answers start end_prompt_index <- start_prompt_index + 1 diff --git a/man/check_quiz_dir.Rd b/man/check_quiz_dir.Rd new file mode 100644 index 0000000..e4614e5 --- /dev/null +++ b/man/check_quiz_dir.Rd @@ -0,0 +1,51 @@ +% Generated by roxygen2: do not edit by hand +% Please edit documentation in R/quiz_formatting.R +\name{check_quiz_dir} +\alias{check_quiz_dir} +\title{Check all quizzes' formatting for Leanpub} +\usage{ +check_quiz_dir( + path = ".", + quiz_dir = "quizzes", + output_dir = "check_reports", + resources_dir = "resources", + report_all = FALSE +) +} +\arguments{ +\item{path}{path to the bookdown or quarto course repository, must have a +`.github` folder which will be used to establish the top of the repo.} + +\item{output_dir}{A relative file path to the folder (existing or not) that the +output check file should be saved to. Default is "check_reports"} + +\item{resources_dir}{A relative file path to the folder (existing or not) that the +ignore_urls.txt file and exclude_files.txt will be found. Default is "resources". +If no ignore_urls.txt file and exclude_files.txt files are found, we will download one.} + +\item{report_all}{Should all URLs that were tested be returned? Default is FALSE +meaning only broken URLs will be reported in the url_checks.tsv file.} + +\item{quiz}{A relative file path to the folder (existing or not) that contains the quizzes +in Leanpub format. Default is "quizzes".} +} +\value{ +A file will be saved that lists the broken URLs will be saved to the specified output_dir. +} +\description{ +Check all quizzes' formatting for Leanpub +} +\examples{ +\dontrun{ + +rmd_dir <- setup_ottr_template(dir = ".", type = "rmd", render = FALSE) + +check_quiz_dir(rmd_dir) + +# If there are broken URLs they will be printed in a list at 'question_error_report.tsv' + +qmd_dir <- setup_ottr_template(dir = ".", type = "quarto", render = FALSE) + +check_quiz_dir(qmd_dir) +} +} diff --git a/tests/testthat/test-quizzes.R b/tests/testthat/test-quizzes.R index 2cf4fc7..2830b3f 100644 --- a/tests/testthat/test-quizzes.R +++ b/tests/testthat/test-quizzes.R @@ -33,3 +33,24 @@ test_that("Make a quiz report", { # Should have a report saved to the quiz directory testthat::expect_true(file.exists(file.path(quiz_dir, "question_error_report.tsv"))) }) + + +test_that("Test real quiz in directory", { + rmd_dir <- setup_ottr_template(dir = ".", type = "rmd", render = FALSE) + + # it shouldn't have any errors with the template + all_quiz_results <- check_quiz_dir(path = rmd_dir, quiz_dir = "quizzes") + + # Expect a list returned + testthat::expect_type(all_quiz_results, "list") + + # Not put a bad quiz in there + file.copy(bad_quiz_path(), file.path(rmd_dir, "quizzes")) + + ## Now check the quizzes in that directory + # The following checks *should also fail* because the bad quiz is in there + testthat::expect_warning(all_quiz_results <- check_quiz_dir(path = rmd_dir, quiz_dir = "quizzes")) + + # Should have a report saved to the quiz directory + testthat::expect_true(file.exists(file.path(rmd_dir, "check_reports", "question_error_report.tsv"))) +}) From f572d237cf5d1c04b879cd9fb4c531c47d86aa84 Mon Sep 17 00:00:00 2001 From: Candace Savonen Date: Mon, 13 Jan 2025 11:45:08 -0500 Subject: [PATCH 2/3] Update test --- tests/testthat/test-quizzes.R | 3 --- 1 file changed, 3 deletions(-) diff --git a/tests/testthat/test-quizzes.R b/tests/testthat/test-quizzes.R index 2830b3f..2886eff 100644 --- a/tests/testthat/test-quizzes.R +++ b/tests/testthat/test-quizzes.R @@ -41,9 +41,6 @@ test_that("Test real quiz in directory", { # it shouldn't have any errors with the template all_quiz_results <- check_quiz_dir(path = rmd_dir, quiz_dir = "quizzes") - # Expect a list returned - testthat::expect_type(all_quiz_results, "list") - # Not put a bad quiz in there file.copy(bad_quiz_path(), file.path(rmd_dir, "quizzes")) From 23de9333113e90d9597ef2e8045630104917307c Mon Sep 17 00:00:00 2001 From: Candace Savonen Date: Mon, 13 Jan 2025 12:39:52 -0500 Subject: [PATCH 3/3] Update quiz docs --- R/quiz_formatting.R | 2 +- man/check_quiz_dir.Rd | 6 +++--- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/R/quiz_formatting.R b/R/quiz_formatting.R index 635fe8c..2b50922 100644 --- a/R/quiz_formatting.R +++ b/R/quiz_formatting.R @@ -7,7 +7,7 @@ utils::globalVariables(c("question", "original", "n", "metadata_check", "index", #' #' @param path path to the bookdown or quarto course repository, must have a #' `.github` folder which will be used to establish the top of the repo. -#' @param quiz A relative file path to the folder (existing or not) that contains the quizzes +#' @param quiz_dir A relative file path to the folder (existing or not) that contains the quizzes #' in Leanpub format. Default is "quizzes". #' @param output_dir A relative file path to the folder (existing or not) that the #' output check file should be saved to. Default is "check_reports" diff --git a/man/check_quiz_dir.Rd b/man/check_quiz_dir.Rd index e4614e5..e3d91d4 100644 --- a/man/check_quiz_dir.Rd +++ b/man/check_quiz_dir.Rd @@ -16,6 +16,9 @@ check_quiz_dir( \item{path}{path to the bookdown or quarto course repository, must have a `.github` folder which will be used to establish the top of the repo.} +\item{quiz_dir}{A relative file path to the folder (existing or not) that contains the quizzes +in Leanpub format. Default is "quizzes".} + \item{output_dir}{A relative file path to the folder (existing or not) that the output check file should be saved to. Default is "check_reports"} @@ -25,9 +28,6 @@ If no ignore_urls.txt file and exclude_files.txt files are found, we will downlo \item{report_all}{Should all URLs that were tested be returned? Default is FALSE meaning only broken URLs will be reported in the url_checks.tsv file.} - -\item{quiz}{A relative file path to the folder (existing or not) that contains the quizzes -in Leanpub format. Default is "quizzes".} } \value{ A file will be saved that lists the broken URLs will be saved to the specified output_dir.