func TestEncDatumCompare(t *testing.T) { defer leaktest.AfterTest(t)() a := &DatumAlloc{} rng, _ := randutil.NewPseudoRand() for kind := range ColumnType_Kind_name { kind := ColumnType_Kind(kind) // TODO(cuongdo,eisen): we don't support persistence for arrays or collated // strings yet if kind == ColumnType_COLLATEDSTRING || kind == ColumnType_INT_ARRAY { continue } typ := ColumnType{Kind: kind} // Generate two datums d1 < d2 var d1, d2 parser.Datum for { d1 = RandDatum(rng, typ, false) d2 = RandDatum(rng, typ, false) if cmp := d1.Compare(d2); cmp < 0 { break } } v1 := DatumToEncDatum(typ, d1) v2 := DatumToEncDatum(typ, d2) if val, err := v1.Compare(a, &v2); err != nil { t.Fatal(err) } else if val != -1 { t.Errorf("compare(1, 2) = %d", val) } asc := DatumEncoding_ASCENDING_KEY desc := DatumEncoding_DESCENDING_KEY noncmp := DatumEncoding_VALUE checkEncDatumCmp(t, a, &v1, &v2, asc, asc, -1, false) checkEncDatumCmp(t, a, &v2, &v1, asc, asc, +1, false) checkEncDatumCmp(t, a, &v1, &v1, asc, asc, 0, false) checkEncDatumCmp(t, a, &v2, &v2, asc, asc, 0, false) checkEncDatumCmp(t, a, &v1, &v2, desc, desc, -1, false) checkEncDatumCmp(t, a, &v2, &v1, desc, desc, +1, false) checkEncDatumCmp(t, a, &v1, &v1, desc, desc, 0, false) checkEncDatumCmp(t, a, &v2, &v2, desc, desc, 0, false) checkEncDatumCmp(t, a, &v1, &v2, noncmp, noncmp, -1, true) checkEncDatumCmp(t, a, &v2, &v1, desc, noncmp, +1, true) checkEncDatumCmp(t, a, &v1, &v1, asc, desc, 0, true) checkEncDatumCmp(t, a, &v2, &v2, desc, asc, 0, true) } }
func TestEncDatumCompare(t *testing.T) { a := &DatumAlloc{} rng, _ := randutil.NewPseudoRand() for typ := range ColumnType_Kind_name { typ := ColumnType_Kind(typ) // TODO(cuongdo): we don't support persistence for arrays yet if typ == ColumnType_INT_ARRAY { continue } // Generate two datums d1 < d2 var d1, d2 parser.Datum for { d1 = RandDatum(rng, typ, false) d2 = RandDatum(rng, typ, false) if cmp := d1.Compare(d2); cmp < 0 { break } } v1 := &EncDatum{} v1.SetDatum(typ, d1) v2 := &EncDatum{} v2.SetDatum(typ, d2) if val, err := v1.Compare(a, v2); err != nil { t.Fatal(err) } else if val != -1 { t.Errorf("compare(1, 2) = %d", val) } asc := DatumEncoding_ASCENDING_KEY desc := DatumEncoding_DESCENDING_KEY noncmp := DatumEncoding_VALUE checkEncDatumCmp(t, a, v1, v2, asc, asc, -1, false) checkEncDatumCmp(t, a, v2, v1, asc, asc, +1, false) checkEncDatumCmp(t, a, v1, v1, asc, asc, 0, false) checkEncDatumCmp(t, a, v2, v2, asc, asc, 0, false) checkEncDatumCmp(t, a, v1, v2, desc, desc, -1, false) checkEncDatumCmp(t, a, v2, v1, desc, desc, +1, false) checkEncDatumCmp(t, a, v1, v1, desc, desc, 0, false) checkEncDatumCmp(t, a, v2, v2, desc, desc, 0, false) checkEncDatumCmp(t, a, v1, v2, noncmp, noncmp, -1, true) checkEncDatumCmp(t, a, v2, v1, desc, noncmp, +1, true) checkEncDatumCmp(t, a, v1, v1, asc, desc, 0, true) checkEncDatumCmp(t, a, v2, v2, desc, asc, 0, true) } }
func TestEncDatumCompare(t *testing.T) { a := &DatumAlloc{} rng, _ := randutil.NewPseudoRand() for typ := ColumnType_Kind(0); int(typ) < len(ColumnType_Kind_value); typ++ { // Generate two datums d1 < d2 var d1, d2 parser.Datum for { d1 = RandDatum(rng, typ, false) d2 = RandDatum(rng, typ, false) if cmp := d1.Compare(d2); cmp < 0 { break } } v1 := &EncDatum{} v1.SetDatum(typ, d1) v2 := &EncDatum{} v2.SetDatum(typ, d2) if val, err := v1.Compare(a, v2); err != nil { t.Fatal(err) } else if val != -1 { t.Errorf("compare(1, 2) = %d", val) } asc := DatumEncoding_ASCENDING_KEY desc := DatumEncoding_DESCENDING_KEY noncmp := DatumEncoding_VALUE checkEncDatumCmp(t, a, v1, v2, asc, asc, -1, false) checkEncDatumCmp(t, a, v2, v1, asc, asc, +1, false) checkEncDatumCmp(t, a, v1, v1, asc, asc, 0, false) checkEncDatumCmp(t, a, v2, v2, asc, asc, 0, false) checkEncDatumCmp(t, a, v1, v2, desc, desc, -1, false) checkEncDatumCmp(t, a, v2, v1, desc, desc, +1, false) checkEncDatumCmp(t, a, v1, v1, desc, desc, 0, false) checkEncDatumCmp(t, a, v2, v2, desc, desc, 0, false) checkEncDatumCmp(t, a, v1, v2, noncmp, noncmp, -1, true) checkEncDatumCmp(t, a, v2, v1, desc, noncmp, +1, true) checkEncDatumCmp(t, a, v1, v1, asc, desc, 0, true) checkEncDatumCmp(t, a, v2, v2, desc, asc, 0, true) } }