diff options
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/testthat.R | 8 | ||||
| -rw-r--r-- | tests/testthat/_snaps/chent.md | 18 | ||||
| -rw-r--r-- | tests/testthat/test_chent.R | 30 | ||||
| -rw-r--r-- | tests/testthat/test_pai.R | 29 | 
4 files changed, 47 insertions, 38 deletions
| diff --git a/tests/testthat.R b/tests/testthat.R index a7a46eb..836723f 100644 --- a/tests/testthat.R +++ b/tests/testthat.R @@ -1,3 +1,11 @@ +# This file is part of the standard setup for testthat. +# It is recommended that you do not modify it. +# +# Where should you do additional test configuration? +# Learn more about the roles of various files in: +# * https://r-pkgs.org/testing-design.html#sec-tests-files-overview +# * https://testthat.r-lib.org/articles/special-files.html +  library(testthat)  library(chents) diff --git a/tests/testthat/_snaps/chent.md b/tests/testthat/_snaps/chent.md new file mode 100644 index 0000000..b214852 --- /dev/null +++ b/tests/testthat/_snaps/chent.md @@ -0,0 +1,18 @@ +# We can initialise an object and add information + +    Code +      print(oct) +    Output +      <chent> +      Identifier $identifier 1-octanol  +      InChI Key $inchikey KBPLFHHGFOOTCA-UHFFFAOYSA-N  +      SMILES string $smiles: +             user     PubChem  +      "CCCCCCCCO" "CCCCCCCCO"  +      Molecular weight $mw: 130.2  +      PubChem synonyms (up to 10): +       [1] "1-octanol"             "Octan-1-ol"            "111-87-5"              +       [4] "N-octanol"             "Octyl alcohol"         "caprylic alcohol"      +       [7] "n-Octyl alcohol"       "Heptyl carbinol"       "1-Hydroxyoctane"       +      [10] "Primary octyl alcohol" + diff --git a/tests/testthat/test_chent.R b/tests/testthat/test_chent.R index 4546423..1f4a186 100644 --- a/tests/testthat/test_chent.R +++ b/tests/testthat/test_chent.R @@ -1,29 +1,21 @@ -context("Generation of chent objects") -  # Check if we can use RDKit  skip_if_no_rdkit <- function() {    if (!chents:::rdkit_available) skip("RDKit is not available via reticulate")  } -oct <- chent$new("1-octanol", smiles = "CCCCCCCCO", rdkit = FALSE, pubchem = FALSE, chyaml = FALSE) - -test_that("We can initialise an object only with identifier and SMILES code", { +test_that("We can initialise an object and add information", { +  oct <- chent$new("1-octanol", smiles = "CCCCCCCCO", rdkit = FALSE, pubchem = FALSE, chyaml = FALSE)    expect_equal(oct$identifier, c(X1.octanol = "1-octanol")) # The name of the identifier is generated using make.names()    expect_equal(oct$inchikey, structure(NA, source = "user"))    expect_equal(oct$smiles, c(user = "CCCCCCCCO")) -}) - -test_that("We can generate a chent object from SMILES using RDKit", { -  skip_if_no_rdkit() -  oct$get_rdkit() -  expect_equivalent(round(oct$mw, 2), 130.23) -}) - -test_that("We can add information retrieved from PubChem via webchem", { -  expect_warning(oct$try_pubchem(), "Overwriting uninitialized InChIKey") -  expect_equivalent(round(oct$mw, 2), 130.23) -  ik = "KBPLFHHGFOOTCA-UHFFFAOYSA-N" -  attr(ik, "source") <- "pubchem" -  expect_equal(oct$inchikey, ik) +  oct$try_pubchem() |>  +    expect_message("Querying PubChem for name 1-octanol") |>  +    expect_warning("Overwriting uninitialized InChIKey") +  expect_equal(oct$inchikey, structure("KBPLFHHGFOOTCA-UHFFFAOYSA-N", source = "pubchem"))    expect_equal(oct$smiles[["PubChem"]], "CCCCCCCCO") +  skip_if_no_rdkit() +  oct$get_rdkit() |>  +    expect_message("Get chemical information from RDKit using user SMILES") +  expect_equal(round(oct$mw, 2), structure(130.23, source = "pubchem")) +  expect_snapshot(print(oct))  }) diff --git a/tests/testthat/test_pai.R b/tests/testthat/test_pai.R index f38672d..0d5264a 100644 --- a/tests/testthat/test_pai.R +++ b/tests/testthat/test_pai.R @@ -1,25 +1,16 @@ -# For manual use of this file -require(chents) -require(testthat) - -context("Generation of pai objects") -  test_that("a pai object is correctly generated", {    skip_on_travis() # server certificate verification failed in curl_fetch_memory() -  glyphosate <- pai$new("glyphosate") +  {glyphosate <- pai$new("glyphosate")} |>  +    expect_message("Querying BCPC for glyphosate") |>  +    expect_message("Querying PubChem for inchikey ") |>  +    expect_message("Get chemical information from RDKit using PubChem SMILES") -  # This did not give results at BCPC in previous times, so it was used to test -  # the corresponding warning. -  #bc <- pai$new("benzalkonium chloride")  - -  expect_equivalent(glyphosate$bcpc$cas, "1071-83-6") -  expect_equivalent(glyphosate$bcpc$formula, "C3H8NO5P") -  expect_equivalent(glyphosate$bcpc$iupac_name, "N-(phosphonomethyl)glycine") +  expect_equal(glyphosate$bcpc$cas, "1071-83-6") +  expect_equal(glyphosate$bcpc$formula, "C3H8NO5P") +  expect_equal(glyphosate$bcpc$iupac_name, "N-(phosphonomethyl)glycine")    expect_equal(names(glyphosate$identifier), "glyphosate")    ik = "XDDAORKBJWWYJS-UHFFFAOYSA-N" -  attr(ik, "source") <- c("bcpc", "pubchem") -  expect_equal(glyphosate$inchikey, ik) -  expect_equivalent(round(glyphosate$mw, 2), 169.07) -  smiles <- "C(C(=O)O)NCP(=O)(O)O" -  expect_equal(glyphosate$smiles[["PubChem"]], smiles) +  expect_equal(glyphosate$inchikey, structure("XDDAORKBJWWYJS-UHFFFAOYSA-N", source = c("bcpc", "pubchem"))) +  expect_equal(round(glyphosate$mw, 2), structure(169.07, source = "pubchem")) +  expect_equal(glyphosate$smiles[["PubChem"]], "C(C(=O)O)NCP(=O)(O)O")  }) | 
