test_that("Test if check all works", {
if (!requireNamespace("gert", quietly = TRUE)) {
stop("please install 'gert' package for these tests to work")
}
origin_repo <- gert::git_init(tempfile("protocol_origin"), bare = TRUE)
on.exit(unlink(origin_repo, recursive = TRUE), add = TRUE)
repo <- gert::git_clone(url = origin_repo,
path = tempfile("protocol_local"), verbose = FALSE)
on.exit(unlink(repo, recursive = TRUE), add = TRUE)
old_wd <- setwd(repo)
on.exit(setwd(old_wd), add = TRUE)
gert::git_config_set(name = "user.name", value = "someone", repo = repo)
gert::git_config_set(name = "user.email", value = "someone@example.org",
repo = repo)
file.create("NEWS.md")
gert::git_add("NEWS.md")
gert::git_commit_all(message = "add empty NEWS repo file")
branch_info <- gert::git_branch_list(repo = repo)
refspec <- branch_info$ref[branch_info$name == gert::git_branch(repo = repo)]
gert::git_push(remote = "origin",
refspec = refspec,
set_upstream = TRUE,
repo = repo)
branch_info <- gert::git_branch_list(repo = repo)
main_branch <- ifelse(any(branch_info$name == "origin/main"),
"main", ifelse(any(branch_info$name == "origin/master"),
"master", "unknown"))
# create a protocol
version_number <- get_version_number()
create_sfp(
title = "Test 1", subtitle = "subtitle", short_title = "water 1",
authors = "Van Calster, Hans", orcids = "0000-0001-8595-8426",
reviewers = "someone else", file_manager = "who?",
version_number = version_number, theme = "water", language = "en"
)
# add, commit and tag it
checklist::new_branch("sfp-101-en", repo = repo)
sfp_staged <- gert::git_add(files = ".")
gert::git_commit_all(message = "sfp-101-en_water-1")
specific_tag <- paste("sfp-101-en", version_number, sep = "-")
generic_tag <- paste("protocols", version_number, sep = "-")
gert::git_tag_create(name = specific_tag, message = "bla")
gert::git_tag_create(name = generic_tag, message = "bla")
branch_info <- gert::git_branch_list(repo = repo)
refspec <- branch_info$ref[branch_info$name == gert::git_branch(repo = repo)]
gert::git_push(remote = "origin",
refspec = refspec,
set_upstream = TRUE,
repo = repo)
#no function fails
expect_no_error(check_all("sfp-101-en", fail = TRUE))
make_news_error <- function(path, version_number) {
news <- readLines(file.path(path, "NEWS.md"))
writeLines(
c(
head(news, 2),
sprintf("\n## [%1$s](../%1$s/index.html)\n", "1900.01"),
rep("- blabla blabla", 1 + rpois(1, lambda = 3)),
tail(news, -2)
),
file.path(path, "NEWS.md")
)
}
make_news_error(
path = file.path("source", "sfp", "1_water", "sfp_101_en_water_1"),
version_number = version_number
)
gert::git_commit_all(message = "sfp-101-en_water-1")
gert::git_push(remote = "origin",
refspec = refspec,
set_upstream = TRUE,
repo = repo)
#fails
expect_error(check_all("sfp-101-en", fail = TRUE))
#both functions fail
expect_error(check_all("sfp-111-nl"))
})
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.