Revision 48ad042083b8bca89eec4dae96dd78416d8c8776 authored by Iddan Aaronsohn on 22 October 2019, 21:50:39 UTC, committed by Iddan Aaronsohn on 22 October 2019, 22:17:08 UTC
1 parent 9c79218
Raw File
and_optimize_test.go
// Copyright 2014 The Cayley Authors. All rights reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
//     http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

package iterator_test

// Tests relating to methods in and-iterator-optimize. Many are pretty simplistic, but
// nonetheless cover a lot of basic cases.

import (
	"context"
	"testing"

	. "github.com/cayleygraph/cayley/graph/iterator"
	"github.com/stretchr/testify/require"
)

func TestNullIteratorAnd(t *testing.T) {
	all := newInt64(1, 3, true)
	null := NewNull()
	a := NewAnd(all, null)
	newIt, changed := a.Optimize(context.TODO())
	if !changed {
		t.Error("Didn't change")
	}
	if _, ok := newIt.(*Null); !ok {
		t.Errorf("Expected null iterator, got %T", newIt)
	}
}

func TestReorderWithTag(t *testing.T) {
	all := NewFixed(Int64Node(3))
	all2 := NewFixed(
		Int64Node(3),
		Int64Node(4),
		Int64Node(5),
		Int64Node(6),
	)
	a := NewAnd()
	// Make all2 the default iterator
	a.AddSubIterator(all2)
	a.AddSubIterator(all)

	_, changed := a.Optimize(context.TODO())
	require.True(t, changed, "expected new iterator")
}

func TestAndStatistics(t *testing.T) {
	all := newInt64(100, 300, true)
	all2 := newInt64(1, 30000, true)
	a := NewAnd()
	// Make all2 the default iterator
	a.AddSubIterator(all2)
	a.AddSubIterator(all)
	ctx := context.TODO()
	stats1, _ := a.Stats(ctx)
	newIt, changed := a.Optimize(ctx)
	require.True(t, changed, "didn't optimize")

	stats2, _ := newIt.Stats(ctx)
	if stats2.NextCost > stats1.NextCost {
		t.Error("And didn't optimize. Next cost old ", stats1.NextCost, "and new ", stats2.NextCost)
	}
}
back to top