示例#1
0
def test_single_continuous_view(pipeline, clean_db):
  """
  Verify that specific continuous views can be dropped and restored
  """
  pipeline.create_cv('test_single0', 'SELECT COUNT(*) FROM stream')
  pipeline.create_cv('test_single1', 'SELECT COUNT(*) FROM stream')
  pipeline.insert('stream', ('x',), [(x,) for x in range(10)])

  result = pipeline.execute('SELECT count FROM test_single0').first()
  assert result['count'] == 10

  result = pipeline.execute('SELECT count FROM test_single1').first()
  assert result['count'] == 10

  _dump(pipeline, 'test_single.sql', cv_name='test_single0')

  pipeline.drop_all_views()
  _restore(pipeline, 'test_single.sql')

  result = pipeline.execute('SELECT count FROM test_single0').first()
  assert result['count'] == 10

  # We didn't dump this one
  result = list(pipeline.execute('SELECT * FROM pg_class WHERE relname LIKE \'%%test_single1%%\''))
  assert not result
示例#2
0
def test_single_continuous_view(pipeline, clean_db):
    """
  Verify that specific continuous views can be dropped and restored
  """
    pipeline.create_cv("test_single0", "SELECT COUNT(*) FROM stream")
    pipeline.create_cv("test_single1", "SELECT COUNT(*) FROM stream")
    pipeline.insert("stream", ("x",), [(x,) for x in range(10)])

    result = pipeline.execute("SELECT count FROM test_single0").first()
    assert result["count"] == 10

    result = pipeline.execute("SELECT count FROM test_single1").first()
    assert result["count"] == 10

    _dump(pipeline, "test_single.sql", cv_name="test_single0")

    pipeline.drop_all_views()
    _restore(pipeline, "test_single.sql")

    result = pipeline.execute("SELECT count FROM test_single0").first()
    assert result["count"] == 10

    # We didn't dump this one
    result = list(pipeline.execute("SELECT * FROM pg_class WHERE relname LIKE '%%test_single1%%'"))
    assert not result
示例#3
0
def test_sliding_windows(pipeline, clean_db):
  """
  Verify that sliding window queries are properly dumped and restored
  """
  pipeline.execute('CREATE CONTINUOUS VIEW sw_v WITH (max_age = \'20 seconds\') AS SELECT count(*) FROM stream')
  pipeline.insert('stream', ('x',), [(x,) for x in range(10)])

  result = pipeline.execute('SELECT count FROM sw_v').first()
  assert result['count'] == 10

  _dump(pipeline, 'test_sw.sql')

  pipeline.drop_all_views()
  _restore(pipeline, 'test_sw.sql')

  result = pipeline.execute('SELECT count FROM sw_v').first()
  assert result['count'] == 10

  # We should still drop back to 0 within 20 seconds
  result = pipeline.execute('SELECT count FROM sw_v').first()
  while result['count'] > 0:
    time.sleep(1)
    result = pipeline.execute('SELECT count FROM sw_v').first()

  result = pipeline.execute('SELECT count FROM sw_v').first()
  assert result['count'] == 0
示例#4
0
def test_sliding_windows(pipeline, clean_db):
    """
  Verify that sliding window queries are properly dumped and restored
  """
    pipeline.execute("CREATE CONTINUOUS VIEW sw_v WITH (max_age = '20 seconds') AS SELECT count(*) FROM stream")
    pipeline.insert("stream", ("x",), [(x,) for x in range(10)])

    result = pipeline.execute("SELECT count FROM sw_v").first()
    assert result["count"] == 10

    _dump(pipeline, "test_sw.sql")

    pipeline.drop_all_views()
    _restore(pipeline, "test_sw.sql")

    result = pipeline.execute("SELECT count FROM sw_v").first()
    assert result["count"] == 10

    # We should still drop back to 0 within 20 seconds
    result = pipeline.execute("SELECT count FROM sw_v").first()
    while result["count"] > 0:
        time.sleep(1)
        result = pipeline.execute("SELECT count FROM sw_v").first()

    result = pipeline.execute("SELECT count FROM sw_v").first()
    assert result["count"] == 0
示例#5
0
def test_schema_only(pipeline, clean_db):
  """
  Verify that it is possible to only dump continuous view schemas and not data
  """
  pipeline.create_cv('test_schema', 'SELECT COUNT(*) FROM stream')
  pipeline.insert('stream', ('x',), [(x,) for x in range(10)])

  result = pipeline.execute('SELECT count FROM test_schema').first()
  assert result['count'] == 10

  _dump(pipeline, 'test_schema.sql', schema_only=True)

  pipeline.drop_all_views()
  _restore(pipeline, 'test_schema.sql')

  # No data loaded
  result = list(pipeline.execute('SELECT count FROM test_schema'))
  assert not result
示例#6
0
def test_schema_only(pipeline, clean_db):
    """
  Verify that it is possible to only dump continuous view schemas and not data
  """
    pipeline.create_cv("test_schema", "SELECT COUNT(*) FROM stream")
    pipeline.insert("stream", ("x",), [(x,) for x in range(10)])

    result = pipeline.execute("SELECT count FROM test_schema").first()
    assert result["count"] == 10

    _dump(pipeline, "test_schema.sql", schema_only=True)

    pipeline.drop_all_views()
    _restore(pipeline, "test_schema.sql")

    # No data loaded
    result = list(pipeline.execute("SELECT count FROM test_schema"))
    assert not result
示例#7
0
def test_dump(pipeline, clean_db):
  """
  Verify that we can dump and restore CVs using INSERT statements
  """
  q = """
  SELECT x::integer %% 100 AS g, avg(x) + 1 AS avg, count(*), count(distinct x) AS distincts FROM stream
  GROUP BY g
  """
  pipeline.create_cv('test_dump', q)

  rows = [(x,) for x in range(1000)]
  pipeline.insert('stream', ('x',), rows)

  def _verify():
    result = pipeline.execute('SELECT count(*) FROM test_dump').first()
    assert result['count'] == 100

    result = pipeline.execute('SELECT sum(avg) FROM test_dump').first()
    assert result['sum'] == 50050

    result = pipeline.execute('SELECT sum(distincts) FROM test_dump').first()
    assert result['sum'] == 1000

  _verify()
  _dump(pipeline, 'test_dump.sql')

  pipeline.drop_all_views()
  _restore(pipeline, 'test_dump.sql')
  _verify()

  # Now verify that we can successfully add more data to the restored CV
  rows = [(x,) for x in range(2000)]
  pipeline.insert('stream', ('x',), rows)

  result = pipeline.execute('SELECT sum(count) FROM test_dump').first()
  assert result['sum'] == 3000

  result = pipeline.execute('SELECT sum(distincts) FROM test_dump').first()
  assert result['sum'] == 2000
示例#8
0
def test_dump(pipeline, clean_db):
    """
  Verify that we can dump and restore CVs using INSERT statements
  """
    q = """
  SELECT x::integer %% 100 AS g, avg(x) + 1 AS avg, count(*), count(distinct x) AS distincts FROM stream
  GROUP BY g
  """
    pipeline.create_cv("test_dump", q)

    rows = [(x,) for x in range(1000)]
    pipeline.insert("stream", ("x",), rows)

    def _verify():
        result = pipeline.execute("SELECT count(*) FROM test_dump").first()
        assert result["count"] == 100

        result = pipeline.execute("SELECT sum(avg) FROM test_dump").first()
        assert result["sum"] == 50050

        result = pipeline.execute("SELECT sum(distincts) FROM test_dump").first()
        assert result["sum"] == 1000

    _verify()
    _dump(pipeline, "test_dump.sql")

    pipeline.drop_all_views()
    _restore(pipeline, "test_dump.sql")
    _verify()

    # Now verify that we can successfully add more data to the restored CV
    rows = [(x,) for x in range(2000)]
    pipeline.insert("stream", ("x",), rows)

    result = pipeline.execute("SELECT sum(count) FROM test_dump").first()
    assert result["sum"] == 3000

    result = pipeline.execute("SELECT sum(distincts) FROM test_dump").first()
    assert result["sum"] == 2000