Sha256: f6ffe2b5d76ce33725440e2c0ee7cfdb6a5c39ad8ba873a6a085cc5e3ae0be4a

Contents?: true

Size: 1.9 KB

Versions: 54

Compression:

Stored size: 1.9 KB

Contents

source("./word-count.R")
library(testthat)

# When comparing lists, all.equal expects the objects to be in the same order
# This expectation instead checks that a) the set of names are the same and
# b) each named object is equal
expect_equal_pairs <- function(object, expected) {
  expect_equal(sort(names(object)),
               sort(names(expected)),
               info = "names in lists differ")
  for (name in names(expected)) {
    expect_equal(object[name], expected[name], info = "list element missing")
  }
}

test_that("count one word", {
  expect_equal_pairs(word_count("word"),
                     list("word" = 1))
})

test_that("count one of each word", {
  expect_equal_pairs(word_count("one of each"),
                     list(
                       "one" = 1,
                       "of" = 1,
                       "each" = 1
                     ))
})

test_that("multiple occurrences of a word", {
  expect_equal_pairs(
    word_count("one fish two fish red fish blue fish"),
    list(
      "one" = 1,
      "fish" = 4,
      "two" = 1,
      "red" = 1,
      "blue" = 1
    )
  )
})

test_that("ignore punctuation", {
  expect_equal_pairs(
    word_count("car : carpet as java : javascript!!&@$%^&"),
    list(
      "car" = 1,
      "carpet" = 1,
      "as" = 1,
      "java" = 1,
      "javascript" = 1
    )
  )
})

test_that("include numbers", {
  expect_equal_pairs(word_count("testing, 1, 2 testing"),
                     list(
                       "testing" = 2,
                       "1" = 1,
                       "2" = 1
                     ))
})

test_that("normalize case", {
  expect_equal_pairs(word_count("go Go GO Stop stop"),
                     list("go" = 3, "stop" = 2))
})

test_that("multiple whitespaces", {
  expect_equal_pairs(word_count(" multiple   whitespaces "),
                     list("multiple" = 1, "whitespaces" = 1))
})

message("All tests passed for exercise: word-count")

Version data entries

54 entries across 54 versions & 1 rubygems

Version Path
trackler-2.2.1.126 tracks/r/exercises/word-count/test_word-count.R
trackler-2.2.1.125 tracks/r/exercises/word-count/test_word-count.R
trackler-2.2.1.124 tracks/r/exercises/word-count/test_word-count.R
trackler-2.2.1.123 tracks/r/exercises/word-count/test_word-count.R
trackler-2.2.1.122 tracks/r/exercises/word-count/test_word-count.R
trackler-2.2.1.121 tracks/r/exercises/word-count/test_word-count.R
trackler-2.2.1.120 tracks/r/exercises/word-count/test_word-count.R
trackler-2.2.1.119 tracks/r/exercises/word-count/test_word-count.R
trackler-2.2.1.118 tracks/r/exercises/word-count/test_word-count.R
trackler-2.2.1.117 tracks/r/exercises/word-count/test_word-count.R
trackler-2.2.1.116 tracks/r/exercises/word-count/test_word-count.R
trackler-2.2.1.115 tracks/r/exercises/word-count/test_word-count.R
trackler-2.2.1.114 tracks/r/exercises/word-count/test_word-count.R
trackler-2.2.1.113 tracks/r/exercises/word-count/test_word-count.R
trackler-2.2.1.111 tracks/r/exercises/word-count/test_word-count.R
trackler-2.2.1.110 tracks/r/exercises/word-count/test_word-count.R
trackler-2.2.1.109 tracks/r/exercises/word-count/test_word-count.R
trackler-2.2.1.108 tracks/r/exercises/word-count/test_word-count.R
trackler-2.2.1.107 tracks/r/exercises/word-count/test_word-count.R
trackler-2.2.1.106 tracks/r/exercises/word-count/test_word-count.R