tests/testthat/test-as.network.numeric.R

#  File tests/testthat/test-as.network.numeric.R in package ergm, part of the
#  Statnet suite of packages for network analysis, https://statnet.org .
#
#  This software is distributed under the GPL-3 license.  It is free,
#  open source, and has the attribution requirements (GPL Section 7) at
#  https://statnet.org/attribution .
#
#  Copyright 2003-2023 Statnet Commons
################################################################################
test_that("Generating directed network", {
  expect_silent(as.network.numeric(x=5, directed = TRUE))
})
test_that("Generating undirected network", {
  expect_silent(as.network.numeric(x=5, directed = FALSE))
})
test_that("Generating Bipartite network", {
  expect_silent(as.network.numeric(x=5, bipartite = 3, directed = FALSE))
})
test_that("Stop when the loop == TRUE", {
  expect_error(as.network.numeric(x=5, loops = TRUE, bipartite = NULL))
  expect_error(as.network.numeric(x=5, loops = TRUE, directed = TRUE))
  expect_error(as.network.numeric(x=5, loops = TRUE, directed = FALSE))
})
test_that("Stop when the multiple == TRUE", {
  expect_error(as.network.numeric(x=5, multiple = TRUE, bipartite = NULL))
  expect_error(as.network.numeric(x=5, multiple = TRUE, directed = TRUE))
  expect_error(as.network.numeric(x=5, multiple = TRUE, directed = FALSE))
})
test_that("Stop when the hyper == TRUE", {
  expect_error(as.network.numeric(x=5, hyper = TRUE, bipartite = NULL))
  expect_error(as.network.numeric(x=5, hyper = TRUE, directed = TRUE))
  expect_error(as.network.numeric(x=5, hyper = TRUE, directed = FALSE))
})
test_that("Stop when the density is out of [0,1]", {
  expect_error(as.network.numeric(x=5, density = -0.1, bipartite = NULL))
  expect_error(as.network.numeric(x=5, density = -0.1, directed = TRUE))
  expect_error(as.network.numeric(x=5, density = -0.1, directed = FALSE))
  expect_error(as.network.numeric(x=5, density =  1.1, bipartite = NULL))
  expect_error(as.network.numeric(x=5, density =  1.1, directed = TRUE))
  expect_error(as.network.numeric(x=5, density =  1.1, directed = FALSE))
})
test_that("Stop when the number of edges is not integer", {
  expect_error(as.network.numeric(x=5, numedges =  2.5, bipartite = NULL))
  expect_error(as.network.numeric(x=5, numedges =  2.5, directed = TRUE))
  expect_error(as.network.numeric(x=5, numedges =  2.5, directed = FALSE))
})
## # TODO: Add this back when explicit directed && bipartite is an error.
##
## test_that("Stop when a Directed bipartite network is specified by the user", {
##   expect_error(as.network.numeric(x=5, numedges =  6L, directed = TRUE, bipartite = 3))
## })

#test_that("Stop when it is missed by the user to specify whether the network is bipartite or directed", {
#  expect_error(as.network.numeric(x=5, numedges =  6L))
#})

## # TODO: Add this back when warnings can be relied on.
## test_that("Warning message when bipartite == TRUE and user missed to specify whether the network is directed or undirected", {
##   expect_warning(as.network.numeric(x=5, numedges =  6L, bipartite = 3))
## })
test_that("Correct number of edges for bipatite graph",{
  expect_equal(network.edgecount(as.network.numeric(x=5, bipartite = 3, directed = FALSE, numedges = 4)),4)
})
test_that("Correct number of edges for undirected graph",{
  expect_equal(network.edgecount(as.network.numeric(x=5, directed = FALSE, numedges = 10)),10)
})
test_that("Correct number of edges for directed graph",{
  expect_equal(network.edgecount(as.network.numeric(x=5, directed = TRUE, numedges = 18)),18)
})
test_that("Correct number of edges for complete graph or when density == 1", {
  expect_equal(network.edgecount(as.network.numeric(x=5, directed = FALSE, density = 1)),10)
})
test_that("specifying a bigger network that the function can generate results in an error",{
  expect_error(as.network.numeric(x=2^50,directed = FALSE))
})
statnet/ergm documentation built on April 17, 2024, 12:21 p.m.