inst/tinytest/test_parse.R

test_parse <- function() {
  zs <- 'q'
  zn <- 5

  do_parse <- function(text, env= parent.frame()) {
    ei <- parse(text = text)[[1]]
    p <- tokenize_for_SQL(ei,
                  colnames = c("c1", "c2"),
                  env = env)
    p$check <- pre_sql_to_query(p$parsed_toks, rquery::rquery_default_db_info())
    p
  }

  ex1 <- do_parse("1")
  expect_equal("1", ex1$check)

  ex2 <- do_parse("c1")
  expect_equal('"c1"', ex2$check)
  expect_equal("c1", ex2$symbols_used)

  ex3 <- do_parse("x1")
  expect_equal("x1", ex3$check)
  expect_equal(character(0), ex3$symbols_used)

  ex4 <- do_parse('"c1"')
  expect_equal("'c1'", ex4$check)

  ex5 <- do_parse("zs")
  expect_equal("'q'", ex5$check)

  ex6 <- do_parse("zn")
  expect_equal("5", ex6$check)

  ex7 <- do_parse("1+2")
  expect_equal("1 + 2", ex7$check)

  ex8 <- do_parse("(1+2)*3")
  expect_equal("( 1 + 2 ) * 3", ex8$check)

  ex9 <- do_parse("!TRUE")
  expect_equal("( NOT ( TRUE ) )", ex9$check)

  ex10 <- do_parse("1==2")
  expect_equal("1 = 2", ex10$check)

  ex11 <- do_parse("ifelse(TRUE,1,2)")
  expect_equal("( CASE WHEN ( TRUE ) THEN ( 1 ) WHEN NOT ( TRUE ) THEN ( 2 ) ELSE NULL END )", ex11$check)

  ex12 <- do_parse("sin(x)")
  expect_equal("sin ( x )", ex12$check)

  ex13 <- do_parse("x := 1+1")
  expect_equal("1 + 1", ex13$check)
  expect_equal("x", ex13$symbols_produced)

  ex13b <- do_parse("x := 1+1")
  expect_equal("1 + 1", ex13b$check)
  expect_equal("x", ex13b$symbols_produced)

  ex14 <- do_parse("rank := rank")
  expect_equal("rank", ex14$check)
  expect_equal("rank", ex14$symbols_produced)

  ex15 <- do_parse("rank := rank()")
  expect_equal("rank ( )", ex15$check)
  expect_equal("rank", ex15$symbols_produced)

  ex17 <- do_parse("x" %:=% "exp(3 * 5)")
  expect_equal("exp ( 3 * 5 )", ex17$check)

  ex18 <- do_parse("y := y + 1")
  expect_equal("y", ex18$symbols_produced)
  expect_equal(character(0), ex18$symbols_used)
  expect_equal("y", ex18$free_symbols)

  invisible(NULL)
}

test_parse()

Try the rquery package in your browser

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

rquery documentation built on Aug. 20, 2023, 9:06 a.m.