|
1 | 1 | df <- data.frame(matrix(1:100, ncol = 5))
|
2 | 2 | mat <- matrix(1:4, ncol = 2)
|
3 |
| -df_mat_mul(df, mat, "z", dplyr::num_range("X", 2:3)) |
4 |
| -test_that("df_mat_mul checks inputs", { |
| 3 | + |
| 4 | +test_that("First input must be a data frame and second input must be a matrix", |
| 5 | + { |
5 | 6 | expect_error(df_mat_mul(30,mat))
|
6 | 7 | expect_error(df_mat_mul(df,20))
|
7 | 8 | })
|
8 | 9 |
|
9 |
| -test_that("Incompatible matrix multipication cannot happen", { |
10 |
| - expect_error(df_mat_mul(df, mat, "z", dplyr::num_range("X", 1:3))) |
| 10 | +test_that("Argument name is a character" ,{ |
| 11 | + expect_error(df_mat_mul(df, mat, 100)) |
| 12 | +}) |
| 13 | + |
| 14 | +test_that("The length of names does not differ from the length of the number |
| 15 | + of outputs" ,{ |
| 16 | + expect_error(df_mat_mul(df, mat, c("a","b","c"), |
| 17 | + dplyr::num_range("X", 2:3))) |
11 | 18 | })
|
12 | 19 |
|
| 20 | +test_that("The number of columns of the first data frame cannot differ from the |
| 21 | + number of rows of the second matrix, hence preventing incompatible |
| 22 | + matrix multiplication", { |
| 23 | + expect_error(df_mat_mul(df, mat, "z", 1:3)) |
| 24 | + }) |
| 25 | + |
| 26 | +X <- df[c(1,4,5)] |
| 27 | +Z <- as.data.frame(as.matrix(df[2:3]) %*% mat) |
| 28 | +colnames(Z) <- c("z1","z2") |
| 29 | +output <- cbind(X,Z) |
| 30 | + |
13 | 31 | test_that("Matrix multiplication is being handled as expected", {
|
14 |
| - X <- df[c(1,4,5)] |
15 |
| - Z <- as.data.frame(as.matrix(df[2:3]) %*% mat) |
16 |
| - colnames(Z) <- c("z1","z2") |
17 |
| - output <- cbind(X,Z) |
18 |
| - expect_identical(df_mat_mul(df,mat, "z", dplyr::num_range("X", 2:3)),output) |
| 32 | + expect_identical(df_mat_mul(df, mat, "z", 2:3),output) |
| 33 | +}) |
| 34 | + |
| 35 | +test_that("Names are used from the out_names field", { |
| 36 | + expect_identical(df_mat_mul(df, mat, c("z1","z2"), 2:3),output) |
| 37 | +}) |
| 38 | + |
| 39 | +test_that("Other tidyselect functionalities are working", { |
| 40 | + mult <- df_mat_mul(df, mat, "z", dplyr::num_range("X", 2:3)) |
| 41 | + expect_identical(mult,output) |
| 42 | + expect_identical(df_mat_mul(df, mat, "z", 2, 3),output) |
19 | 43 | })
|
0 commit comments