File: unittest.R

package info (click to toggle)
swig 4.4.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 45,980 kB
  • sloc: cpp: 54,284; ansic: 29,022; java: 17,595; python: 12,734; cs: 10,421; ruby: 7,263; yacc: 6,501; makefile: 5,860; javascript: 5,538; sh: 5,422; perl: 4,246; php: 3,733; ml: 2,198; tcl: 2,015; lisp: 1,448; xml: 115
file content (43 lines) | stat: -rw-r--r-- 724 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
unittest <- function (x,y) {
  if (all(x==y)) {
    print("PASS")
  } else {
    print("FAIL")
    print(paste(x, " != ", y))
    stop("Test failed")
  }
}

unittesttol <- function(x,y,z) {
  if (all(abs(x-y) < z)) {
    print("PASS")
  } else {
    print("FAIL")
    stop("Test failed")
  }
}

unittest_sequence <- function (x,y) {
  x = as.vector(x)
  y = as.vector(y)
  
  if (length(x) == 0 && length(y) == 0) {
    print("PASS")
    return()
  }
  
  if (class(x[1]) != class(y[1])) {
    print("FAILED")
    stop(paste("Test failed: ", class(x[1]), " != ", class(y[1])))
  }
  
  try(expr = {
    if (!any(x != y)) {
      print("PASS")
      return()
    }
  }, silent = T)
  
  print("FAIL")
  stop("Test failed")
}