tests/testthat/test_computeSummaryStatisticsTable-total.R

context("Compute summary statistics table with totals")

test_that("The totals are correctly extracted from the data by default", {
			
	# data with different number of subjects/records per treatment
	data <- data.frame(
		USUBJID = c(1, 1, 2, 3, 4, 4, 5),
		TRT = rep(c("A", "B"), times = c(4, 3)),
		ADECOD = c("a", "b", "a", "c", "d", "a", "b"),
		stringsAsFactors = FALSE
	)
	
	sumTable <- computeSummaryStatisticsTable(
		data = data,
		var = "ADECOD",
		colVar = "TRT"
	)
	# by default data total extracted from the dataset directly
	sumTableTotal <- subset(sumTable, isTotal)
	sumTableTotal <- sumTableTotal[match(c("A", "B"), sumTableTotal$TRT), ]
	
	# # subjects/records for total is correct
	expect_equal(sumTableTotal$statN, c(3, 2))
	expect_equal(sumTableTotal$statm, c(4, 3))
	
	# number of subjects in 'total' same as total used for percentage by default
	expect_equal(
		sumTable$statPercTotalN, 
		sumTableTotal[match(sumTable$TRT, sumTableTotal$TRT), "statN"]
	)
			
})

test_that("The totals are correctly extracted from a specified dataset", {
			
	# data with different number of subjects/records per treatment
	data <- data.frame(
		USUBJID = c(1, 1, 2, 3, 4, 4, 5),
		TRT = rep(c("A", "B"), times = c(4, 3)),
		ADECOD = c("a", "b", "a", "c", "d", "a", "b"),
		stringsAsFactors = FALSE
	)
	
	## correct spec
	
	# data with different number of subjects/records
	dataTotal <- data.frame(
		TRT = rep(c("A", "B"), c(6, 4)),
		USUBJID = c(c(1, seq.int(5)), c(1, seq.int(3)))
	)
			
	sumTable <- computeSummaryStatisticsTable(
		data = data,
		var = "ADECOD",
		colVar = "TRT",
		dataTotal = dataTotal
	)
			
	# data total extracted from a specified dataset directly
	sumTableTotal <- subset(sumTable, isTotal)
	sumTableTotal <- sumTableTotal[match(c("A", "B"), sumTableTotal$TRT), ]
			
	# # subjects/records for total is correct
	expect_equal(sumTableTotal$statN, c(5, 3))
	expect_equal(sumTableTotal$statm, c(6, 4))
			
	# number of subjects in 'total' same as total used for percentage by default
	expect_equal(
		sumTable$statPercTotalN, 
		sumTableTotal[match(sumTable$TRT, sumTableTotal$TRT), "statN"]
	)
	
})

test_that("Warnings are generated if the column variable is not available in the dataset for totals", {
			
	# data with different number of subjects/records per treatment
	data <- data.frame(
		USUBJID = c(1, 1, 2, 3, 4, 4, 5),
		TRT = rep(c("A", "B"), times = c(4, 3)),
		ADECOD = c("a", "b", "a", "c", "d", "a", "b"),
		stringsAsFactors = FALSE
	)

	dataTotal <- data.frame(
		USUBJID = c(c(1, seq.int(5)), c(1, seq.int(3)))
	)
	w <- capture_warnings(
		sumTable <- computeSummaryStatisticsTable(
			data = data,
			var = "ADECOD",
			colVar = "TRT",
			dataTotal = dataTotal
		)
	)
	expect_match(w, ".*colVarTotal are ignored because they are not available in: total dataset.", all = FALSE)
	expect_match(w, ".*colVarTotalPerc are ignored because they are not available in: total dataset for percentage.", all = FALSE)
	expect_equal(sum(sumTable$isTotal), 1) # total computed across columns
	
})

test_that("The percentages are correctly extracted from a specified dataset", {

	# data with different number of subjects/records per treatment
	data <- data.frame(
		USUBJID = c(1, 1, 2, 3, 4, 4, 5),
		TRT = rep(c("A", "B"), times = c(4, 3)),
		ADECOD = c("a", "b", "a", "c", "d", "a", "b"),
		stringsAsFactors = FALSE
	)	
	
	dataTotalPerc <- data.frame(
		TRT = rep(c("A", "B"), c(6, 4)),
		USUBJID = c(c(1, seq.int(5)), c(1, seq.int(3)))
	)
	
	sumTable <- computeSummaryStatisticsTable(
		data = data,
		var = "ADECOD",
		colVar = "TRT",
		dataTotalPerc = dataTotalPerc
	)
	
	# percentage is computed from a specified dataset
	expect_true(all(subset(sumTable, TRT == "A")$statPercTotalN == 5))
	expect_true(all(subset(sumTable, TRT == "B")$statPercTotalN == 3))
	
	expect_equal(sumTable$statPercN, with(sumTable, statN/statPercTotalN)*100)
	
	# data total is still extracted from the dataset directly
	sumTableTotal <- subset(sumTable, isTotal)
	sumTableTotal <- sumTableTotal[match(c("A", "B"), sumTableTotal$TRT), ]
	
	# # subjects/records for total is correct
	expect_equal(sumTableTotal$statN, c(3, 2))
	expect_equal(sumTableTotal$statm, c(4, 3))
	
})

test_that("A warning is generated if the column variable for percentages is not available in the dataset for percentages", {
			
	data <- data.frame(
		USUBJID = c(1, 1, 2, 3, 4, 4, 5),
		TRT = rep(c("A", "B"), times = c(4, 3)),
		ADECOD = c("a", "b", "a", "c", "d", "a", "b"),
		stringsAsFactors = FALSE
	)

	dataTotalPerc <- data.frame(
		USUBJID = c(c(1, seq.int(5)), c(1, seq.int(3)))
	)
	expect_warning(
		sumTable <- computeSummaryStatisticsTable(
			data = data,
			var = "ADECOD",
			colVar = "TRT",
			dataTotalPerc = dataTotalPerc
		),
		".*colVarTotalPerc are ignored because they are not available in: total dataset for percentage."
	)
})

test_that("The row totals are correctly extracted from a specified dataset", {
			
	# data
	data <- data.frame(
		USUBJID = c(1, 2, 4, 5),
		TRT = c("A", "A", "B", "B"),
		ABODSYS = c("AB", "AB", "CD", "AB"),
		ADECOD = c("a", "b", "d", "a")
	)
			
	# row total dataset: 
	# add one subject for TRT: B - ABODSYS: CD
	dataTotalRow <- data.frame(
		USUBJID = c(1, 2, 4, 5, 6),
		TRT = c("A", "A", "B", "B", "B"),
		ABODSYS = c("AB", "AB", "CD", "CD", "AB"),
		ADECOD = c("a", "b", "d", "e", "a")
	)
	
	# summary table
	summaryTable <- computeSummaryStatisticsTable(
		data = data,
		colVar = "TRT",
		rowVar = c("ABODSYS", "ADECOD"),
		rowVarTotalInclude = c("ABODSYS", "ADECOD"),
		dataTotalRow = dataTotalRow
	)
	
	# row totals across AEBODYS (by column)
	expect_equal(
		object = subset(summaryTable, 
			subset = (ADECOD == "Total" & ABODSYS == "Total"), 
			select = c("TRT", "statN", "statm"),
		),
		expected = subset(
			computeSummaryStatisticsTable(
				data = dataTotalRow,
				colVar = "TRT"
			),
			subset = !isTotal,
			select = c("TRT", "statN", "statm")
		),
		check.attributes = FALSE
	)
	
	# row totals across AEDECOD (by column)	
	expect_equal(
		object = subset(summaryTable, 
			subset = (ADECOD == "Total" & ABODSYS != "Total"), 
			select = c("TRT", "ABODSYS", "statN", "statm")
		),
		expected = subset(
			computeSummaryStatisticsTable(
				data = dataTotalRow,
				colVar = "TRT",
				rowVar = "ABODSYS"
			),
			subset = !isTotal,
			select = c("TRT", "ABODSYS", "statN", "statm")
		),
		check.attributes = FALSE
	)
	
})

test_that("An error is generated if the row or column variables are not available in the dataset for percentages", {
	
	# data with different number of subjects/records per treatment
	data <- data.frame(
		USUBJID = c(1, 1, 2, 3, 4, 4, 5),
		TRT = rep(c("A", "B"), times = c(4, 3)),
		ABODSYS = c("AB", "AB", "AB", "CD", "CD", "AB", "AB"),
		ADECOD = c("a", "b", "a", "c", "d", "a", "b"),
		stringsAsFactors = FALSE
	)
			
	# variables (columns, rows) missing in dataTotalRow
	expect_error(
		computeSummaryStatisticsTable(
			data = data,
			colVar = "TRT",
			rowVar = c("ABODSYS", "ADECOD"),
			rowVarTotalInclude = c("ABODSYS", "ADECOD"),
			dataTotalRow = data[, "USUBJID", drop = FALSE]
		),
		"*not available.*dataset for row total"
	)
	
})

test_that("An error is generated if the dataset for percentages is specified only for a subset of the row variables", {
			
	# data with different number of subjects/records per treatment
	data <- data.frame(
		USUBJID = c(1, 1, 2, 3, 4, 4, 5),
		TRT = rep(c("A", "B"), times = c(4, 3)),
		ABODSYS = c("AB", "AB", "AB", "CD", "CD", "AB", "AB"),
		ADECOD = c("a", "b", "a", "c", "d", "a", "b"),
		stringsAsFactors = FALSE
	)
			
	
	# dataset specified as a list but not for all variables
	expect_error(
		computeSummaryStatisticsTable(
			data = data,
			colVar = "TRT",
			rowVar = c("ABODSYS", "ADECOD"),
			rowVarTotalInclude = c("ABODSYS", "ADECOD"),
			dataTotalRow = list(ABODSYS = data)
		),
		"Dataset for row total missing for:.*ADECOD.*"
	)
	
})

Try the inTextSummaryTable package in your browser

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

inTextSummaryTable documentation built on Sept. 12, 2023, 5:06 p.m.