tests/testthat/test_subset.R

# vim:textwidth=80:expandtab:shiftwidth=4:softtabstop=4

# Tests of subsetting, which was seen to be a problem in issue 563. The tests
# here are all for CTD objects, although it would be sensible to test other
# objects too.

library(oce)

test_that("subset a CTD by pressure (1)", {
    make_ctd <- function(start, end) {
        pre <- seq(0, 100, 1)
        sal <- 35 + pre / 100
        tem <- 20 - pre / 100
        d <- as.ctd(sal, tem, pre)
        d <- subset(d, start <= pressure & pressure <= end)
    }
    focus <- c(20, 30)
    d <- make_ctd(focus[1], focus[2])
    expect_equal(d[["pressure"]], 20:30)
})

test_that("subset a CTD by pressure (2)", {
    make_ctd <- function(start, end) {
        start <- 20
        end <- 30
        pre <- seq(0, 100, 1)
        sal <- 35 + pre / 100
        tem <- 20 - pre / 100
        d <- as.ctd(sal, tem, pre)
        d <- subset(d, start <= pressure & pressure <= end)
    }
    focus <- c(20, 30)
    d <- make_ctd(focus[1], focus[2])
    expect_equal(d[["pressure"]], 20:30)
})

test_that("subset a CTD by pressure (3)", {
    start <- 20
    end <- 30
    pre <- seq(0, 100, 1)
    sal <- 35 + pre / 100
    tem <- 20 - pre / 100
    d <- as.ctd(sal, tem, pre)
    d <- subset(d, start <= pressure & pressure <= end)
    expect_equal(d[["pressure"]], 20:30)
})

test_that("subset a CTD by pressure (4)", {
    wrapper <- function(start, end) {
        make_ctd <- function(start, end) {
            pre <- seq(0, 100, 1)
            sal <- 35 + pre / 100
            tem <- 20 - pre / 100
            d <- as.ctd(sal, tem, pre)
            d <- subset(d, start <= pressure & pressure <= end)
        }
        make_ctd(start, end)
    }
    focus <- c(20, 30)
    d <- wrapper(focus[1], focus[2])
    expect_equal(d[["pressure"]], 20:30)
})

test_that("subset a CTD by pressure (5)", {
    outerWrapper <- function(start, end) {
        wrapper <- function(start, end) {
            make_ctd <- function(start, end) {
                pre <- seq(0, 100, 1)
                sal <- 35 + pre / 100
                tem <- 20 - pre / 100
                d <- as.ctd(sal, tem, pre)
                d <- subset(d, start <= pressure & pressure <= end)
            }
            make_ctd(start, end)
        }
        wrapper(start, end)
    }
    focus <- c(20, 30)
    d <- outerWrapper(focus[1], focus[2])
    expect_equal(d[["pressure"]], 20:30)
})

test_that("subset a CTD by pressure (6)", {
    make_ctd <- function(start, end) {
        start <- 20
        end <- 30
        pre <- seq(0, 100, 1)
        sal <- 35 + pre / 100
        tem <- 20 - pre / 100
        d <- as.ctd(sal, tem, pre)
        d <- subset(d, start <= pressure & pressure <= end)
    }
    focus <- c(1, 100)
    d <- make_ctd(focus[1], focus[2])
    expect_equal(d[["pressure"]], 20:30)
})

Try the oce package in your browser

Any scripts or data that you put into this service are public.

oce documentation built on July 9, 2023, 5:18 p.m.