tests/testthat/test-corpus_subset.R

context('test corpus_subset')

test_that("head, tail.corpus work as expected", {
    corp <- corpus_subset(data_corpus_inaugural, Year < 2018)
    expect_equal(
        docnames(head(corp, 3)),
        c("1789-Washington", "1793-Washington", "1797-Adams")
    )
    expect_equal(
        docnames(head(corp, -55)),
        c("1789-Washington", "1793-Washington", "1797-Adams")
    )
    expect_equal(
        docnames(tail(corp, 3)),
        c("2009-Obama", "2013-Obama", "2017-Trump")
    )
    expect_equal(
        docnames(tail(corp, -55)),
        c("2009-Obama", "2013-Obama", "2017-Trump")
    )
})


test_that("corpus_subset works", {
    txt <- c(doc1 = "This is a sample text.\nIt has three lines.\nThe third line.",
             doc2 = "one\ntwo\tpart two\nthree\nfour.",
             doc3 = "A single sentence.",
             doc4 = "A sentence with \"escaped quotes\".")
    dat <- data.frame(var_numeric = 10:13, var_factor = factor(c("A", "B", "A", "B")), 
                      var_char = letters[1:4])
    
    corp <- corpus(txt, docvars = dat)
    expect_equal(ndoc(corpus_subset(corp, var_factor == "B")), 2)
    expect_equal(docnames(corpus_subset(corp, var_factor == "B")), 
                 c("doc2", "doc4"))
    
    corp_nodvar <- corpus(txt)
    expect_equal(ndoc(corpus_subset(corp_nodvar, LETTERS[1:4] == "B")), 1)
    expect_equal(docnames(corpus_subset(corp_nodvar, LETTERS[1:4] == "B")), 
                 c("doc2"))
    
})
koheiw/quanteda.core documentation built on Sept. 21, 2020, 3:44 p.m.