tests/testthat/test-geos-basic-strtree.R

test_that("geos_basic_strtree objects can be created", {
  tree <- geos_basic_strtree()
  expect_s3_class(tree, "geos_basic_strtree")
  expect_false(geos_basic_strtree_finalized(tree))
  expect_identical(geos_basic_strtree_size(tree), 0L)
})

test_that("geos_basic_strtree objects can be created with initial items", {
  tree <- geos_basic_strtree(wk::xy(1:3, 1:3))
  expect_identical(geos_basic_strtree_size(tree), 3L)
})

test_that("can insert geos_geometry to geos_basic_strtree", {
  tree <- geos_basic_strtree()

  geos_basic_strtree_insert(tree, geos_geometry())
  expect_identical(geos_basic_strtree_size(tree), 0L)

  expect_identical(
    geos_basic_strtree_insert(
      tree,
      as_geos_geometry(c("POINT (0 1)", "POINT (2 3)"))
    ),
    1:2
  )

  expect_identical(
    geos_basic_strtree_insert(
      tree,
      as_geos_geometry(c("POINT (0 1)", "POINT (2 3)"))
    ),
    3:4
  )
})

test_that("can insert non-geos_geometry to geos_basic_strtree", {
  tree <- geos_basic_strtree()

  geos_basic_strtree_insert(tree, wk::wkt())
  expect_identical(geos_basic_strtree_size(tree), 0L)

  expect_identical(
    geos_basic_strtree_insert(
      tree,
      wk::wkt(c("POINT (0 1)", "POINT (2 3)"))
    ),
    1:2
  )

  expect_identical(
    geos_basic_strtree_insert(
      tree,
      wk::wkt(c("POINT (0 1)", "POINT (2 3)"))
    ),
    3:4
  )
})

test_that("geos_basic_strtree can be queried", {
  tree <- geos_basic_strtree()
  geos_basic_strtree_insert(tree, wk::wkt(c("POINT (1 1)", "POINT (3 3)")))
  geos_basic_strtree_query(tree, wk::rct(0, 0, 2, 2))

  expect_true(geos_basic_strtree_finalized(tree))

  expect_identical(
    geos_basic_strtree_query(tree, wk::rct(0, 0, 2, 2)),
    data.frame(x = 1L, tree = 1L)
  )

  expect_identical(
    geos_basic_strtree_query(tree, wk::rct(2, 2, 4, 4)),
    data.frame(x = 1L, tree = 2L)
  )

  expect_identical(
    geos_basic_strtree_query(tree, as_geos_geometry(NA_character_)),
    data.frame(x = integer(), tree = integer())
  )
})

test_that("geos_basic_strtree can be queried with limit and fill", {
  tree <- geos_basic_strtree()
  geos_basic_strtree_insert(tree, wk::wkt(c("POINT (1 1)", "POINT (3 3)")))

  expect_identical(
    geos_basic_strtree_query(
      tree,
      wk::wkt(c("POINT (3 3)", "POINT (4 4)")),
      limit = 1,
      fill = TRUE
    ),
    data.frame(x = 1:2, tree = c(2L, NA_integer_))
  )
})

test_that("geos_basic_strtree can be queried with a filter", {
  triangle <- wk::wkt("POLYGON ((0 0, 0 1, 1 0, 0 0))")
  point <- wk::wkt(c("POINT (0.1 0.1)", "POINT (0.6 0.6)"))

  tree <- geos_basic_strtree()
  geos_basic_strtree_insert(tree, point)
  geos_basic_strtree_query(tree, triangle)

  expect_identical(
    geos_basic_strtree_query(tree, triangle),
    data.frame(x = c(1L, 1L), tree = c(1L, 2L))
  )

  expect_identical(
    geos_basic_strtree_query_filtered(
      tree,
      triangle,
      point,
      geos_prepared_intersects
    ),
    data.frame(x = 1L, tree = 1L)
  )
})

Try the geos package in your browser

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

geos documentation built on June 7, 2023, 6:04 p.m.