tests/testthat/test-url-operations.R

# URL Operations Tests

test_that("scan_url validates input correctly", {
  expect_error(scan_url(), "Assertion on 'url' failed")
  expect_error(scan_url(NULL), "Assertion on 'url' failed")
  expect_error(scan_url(123), "Assertion on 'url' failed")
  expect_error(
    scan_url(""),
    "All elements must have at least 1 characters"
  )
})

test_that("url_report validates input correctly", {
  expect_error(url_report(), "Assertion on 'url_id' failed")
  expect_error(url_report(NULL), "Assertion on 'url_id' failed")
  expect_error(url_report(123), "Assertion on 'url_id' failed")
  expect_error(
    url_report(""),
    "All elements must have at least 1 characters"
  )
})

test_that("get_url_comments validates input correctly", {
  expect_error(get_url_comments(), "Assertion on 'url_id' failed")
  expect_error(get_url_comments(NULL), "Assertion on 'url_id' failed")
  expect_error(get_url_comments(123), "Assertion on 'url_id' failed")
  expect_error(
    get_url_comments(""),
    "All elements must have at least 1 characters"
  )
})

test_that("post_url_comments validates input correctly", {
  expect_error(post_url_comments(), "Assertion on 'url_id' failed")
  expect_error(post_url_comments("validurl"), "Assertion on 'comment' failed")
  expect_error(
    post_url_comments("validurl", ""),
    "All elements must have at least 1 characters"
  )
})

test_that("get_url_votes validates input correctly", {
  expect_error(get_url_votes(), "Assertion on 'url_id' failed")
  expect_error(get_url_votes(NULL), "Assertion on 'url_id' failed")
  expect_error(
    get_url_votes(""),
    "All elements must have at least 1 characters"
  )
})

test_that("post_url_votes validates input correctly", {
  expect_error(post_url_votes(), "Assertion on 'url_id' failed")
  expect_error(
    post_url_votes("validurl"),
    "Verdict must be either 'harmless' or 'malicious'"
  )
  expect_error(
    post_url_votes("validurl", "invalid"),
    "Verdict must be either 'harmless' or 'malicious'"
  )
})

test_that("get_url_relationships validates input correctly", {
  expect_error(get_url_relationships(), "Assertion on 'url_id' failed")
  expect_error(
    get_url_relationships("validurl"),
    "Assertion on 'relationship' failed"
  )
  expect_error(
    get_url_relationships("validurl", ""),
    "All elements must have at least 1 characters"
  )
})

test_that("rescan_url validates input correctly", {
  expect_error(rescan_url(), "Assertion on 'url_id' failed")
  expect_error(rescan_url(NULL), "Assertion on 'url_id' failed")
  expect_error(
    rescan_url(""),
    "All elements must have at least 1 characters"
  )
})

test_that("URL encoding works correctly", {
  skip_if_not_installed("base64enc")

  test_url <- "http://www.google.com"
  encoded <- base64enc::base64encode(charToRaw(test_url))
  encoded <- gsub("=+$", "", encoded)

  expect_true(nchar(encoded) > 0)
  expect_false(grepl("=", encoded))
})

test_that("URL operations work with mocked responses", {
  skip_if_not_installed("httptest")
  skip_if(Sys.getenv("VirustotalToken") == "", "API key not set")

  expect_true(exists("scan_url"))
  expect_true(exists("url_report"))
})

Try the virustotal package in your browser

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

virustotal documentation built on April 13, 2026, 9:07 a.m.