Skip to content

Commit

Permalink
catch case if students specified function without function keyword
Browse files Browse the repository at this point in the history
  • Loading branch information
Filip Schouwenaars committed Apr 19, 2018
1 parent 7e33315 commit 2fe2f83
Show file tree
Hide file tree
Showing 3 changed files with 26 additions and 128 deletions.
3 changes: 3 additions & 0 deletions R/utils-pd.R
Original file line number Diff line number Diff line change
Expand Up @@ -90,6 +90,9 @@ extract_function_definition <- function(pd, name) {
if(length(sub_pds) == 1) {
pd <- sub_pds[[1]]
function_parents <- pd$parent[pd$token == "FUNCTION"]
if (length(function_parents) == 0) {
return(NULL)
}
fundefs <- lapply(function_parents, function(function_parent) {
last_brother <- tail(pd$id[pd$parent == function_parent], 1)
code <- getParseText(pd, last_brother)
Expand Down
38 changes: 21 additions & 17 deletions tests/testthat/test-check-fun-def.R
Original file line number Diff line number Diff line change
Expand Up @@ -208,6 +208,27 @@ test_that("check_fun_def - errs appropriately", {
# TODO
})

test_that("embedded check_fun_def - outer function", {
lst <- list()
lst$DC_SOLUTION <- "my_fun <- function(x) { twice <- function(a) { a * 2 }; twice(x) }"
lst$DC_SCT <- "ex() %>% check_fun_def('my_fun') %>% check_body()"
lst$DC_CODE <- lst$DC_SOLUTION
capture.output(output <- test_it(lst))
passes(output)
})

test_that("check_fun_def - function instead of function def", {
lst <- list()
lst$DC_SOLUTION <- "my_fun <- function(x) { x + 2 }"
lst$DC_SCT <- "ex() %>% check_fun_def('my_fun') %>% check_body()"
lst$DC_CODE <- "my_fun <- mean"
capture.output(output <- test_it(lst))
fails(output, mess_patt = "Did you correctly define")
})

test_that("embedded check_fun_def - inner function", {
# TODO not supported yet
})

context("test_function_definition (old)")

Expand Down Expand Up @@ -376,20 +397,3 @@ test_that("test_function_definition works with control structure in there", {
capture.output(output <- test_it(lst))
passes(output)
})

test_that("embedded check_fun_def - outer function", {
expect_equal(TRUE, TRUE)
lst <- list()
lst$DC_SOLUTION <- "my_fun <- function(x) { twice <- function(a) { a * 2 }; twice(x) }"
lst$DC_SCT <- "fundef <- ex() %>% check_fun_def('my_fun')
fundef %>% check_arguments()
innerfun_def <- fundef %>% check_body()"

lst$DC_CODE <- lst$DC_SOLUTION
capture.output(output <- test_it(lst))
passes(output)
})

test_that("embedded check_fun_def - inner function", {
# TODO not supported yet
})
113 changes: 2 additions & 111 deletions tests/testthat/test-content-examples.R
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
context("content_examples")

test_that("exercise intermediate R", {
test_that("exercise intermediate r (1)", {
lst <- list()
lst$DC_CODE <- "today <- Sys.Date()\nday1 <- today - 11"
lst$DC_SOLUTION <- "today <- Sys.Date()\nday1 <- today - 11"
Expand All @@ -9,7 +9,7 @@ test_that("exercise intermediate R", {
passes(output)
})

test_that("exercise intermediate r", {
test_that("exercise intermediate r (2)", {
lst <- list()
lst$DC_PEC <- "linkedin <- c(16, 9, 13, 5, 2, 17, 14)"
lst$DC_SOLUTION <- "for (li in linkedin) { print(li) }"
Expand All @@ -23,16 +23,6 @@ test_that("exercise intermediate r", {
passes(output)
})

test_that("exercise intermediate r - 2", {
lst <- list()
lst$DC_PEC <- 'load(url("http://s3.amazonaws.com/assets.datacamp.com/production/course_753/datasets/chapter2.RData"))'
lst$DC_CODE <- 'str(logs)\nlogs[[11]]$detaidls\nclass(logs[[1]]$timestamp)'
lst$DC_SOLUTION <- lst$DC_CODE
lst$DC_SCT <- 'test_function("class", "x", incorrect_msg = "Have you passed the `timestamp` component of `logs[[1]]` to `class()`?")'
output <- test_it(lst)
passes(output)
})

test_that("exercise ggplot2 - v1", {
lst <- list()
lst$DC_PEC <- "library(ggplot2)"
Expand Down Expand Up @@ -67,116 +57,17 @@ test_that("exercise ggplot2 - v2", {
test_function_v2('qplot', c('data', 'x', 'y'), eval = c(T, F, F), index = 2)
test_function_v2('qplot', c('data', 'x', 'y','geom'), eval = c(T, F, F, F), index = 3)
test_error()
success_msg('Good job!')
"
lst$DC_SOLUTION <- "
# qplot() with x only
qplot(factor(cyl), data = mtcars)
# qplot() with x and y
qplot(factor(cyl), factor(vs), data = mtcars)
# qplot() with geom set to jitter manually
qplot(factor(cyl), factor(vs), data = mtcars, geom = 'jitter')
"
lst$DC_CODE <- lst$DC_SOLUTION
output <- test_it(lst)
passes(output)
})

test_that("R for sas, spss, stata", {
lst <- list()
lst$DC_PEC <- "
load(url(\"http://s3.amazonaws.com/assets.datacamp.com/course/Bob/mydata100.RData\"))
pretest <- mydata100$pretest
gender <- mydata100$gender
"
lst$DC_SOLUTION <- "
by(pretest,
gender,
function(x){ c(mean(x, na.rm = TRUE),
sd(x, na.rm = TRUE),
median(x = x, na.rm = TRUE)) })
"
lst$DC_CODE <- lst$DC_SOLUTION
lst$DC_SCT <- '
test_error()
test_function("by", "data",
incorrect_msg = "There is something wrong with your data argument in the <code>by()</code> function.",
not_called_msg = "Use the <code>by()</code> function with the data specified as first argument.")
test_function("by", "INDICES",
incorrect_msg = "There is something wrong with the grouping of your <code>by()</code> function.",
not_called_msg = "Use the <code>by()</code> function with <code>gender</code> as grouping factor.")
test_function("by", "FUN",
incorrect_msg = "There is something wrong with the anonymous function in the <code>by()</code> function.",
not_called_msg = "Use the <code>by()</code> function with the anonymous that needs to be applied.")
'
output <- test_it(lst)
passes(output)
})

test_that("intermediate r practice", {
lst <- list()
lst$DC_PEC <- 'load(url("http://s3.amazonaws.com/assets.datacamp.com/production/course_753/datasets/chapter2.RData"))'
lst$DC_SCT <- '
test_function("str", "object")
#test_output_contains("logs[[11]]$details")
#test_function("class", "x")
success_msg("AWESOME!")
'
lst$DC_SOLUTION <- "
str(logs)
logs[[11]]$details
class(logs[[1]])
"
lst$DC_CODE <- "
print(logs)
print(logs[[11]])
print(str(logs[[1]]$timestamp))
"
output <- test_it(lst)
fails(output)
})

test_that("exercise eda", {
lst <- list()
lst$DC_PEC <- 'source("http://s3.amazonaws.com/assets.datacamp.com/production/course_1414/datasets/shared.R")
votes_joined <- read_dataset("votes_joined")'
lst$DC_CODE <- '# Load the tidyr package
library(tidyr)
# Gather the six mu/nu/di/hr/co/ec columns
votes_joined %>%
gather(topic, has_topic, me:ec)
# Perform gather again, then filter
votes_gathered <- votes_joined %>%
gather(topic, has_topic, me:ec) %>%
filter(has_topic == 1)'
lst$DC_SOLUTION <- lst$DC_CODE
lst$DC_SCT <- '
test_library_function("tidyr")
test_function("gather", args = c("data", "key", "value"), eval = c(T, F, F))
test_correct({
test_data_frame("votes_gathered", incorrect_msg = "Did you gather the six columns (`mu`, `nu`, `di`, `hr`, `co`, and `ec`) and filter such that `has_topic == 1`?")
}, {
test_function("gather", args = c("data", "key", "value"), eval = c(T, F, F))
test_function("filter")
})
test_error()
success_msg("Awesome job!")
'

output <- test_it(lst)
passes(output)
output <- test_it(lst)
passes(output)

})

# # NOT FIXED!
# test_that("exercise cleaning data", {
# lst <- list()
Expand Down

0 comments on commit 2fe2f83

Please sign in to comment.