Files
dolt/dataset/dataset_test.go
T
Dan Willhite 4852067aad Fix concurrency overwrite on dataset.
When there are two dataset clients working on the same empty dataset. The second one to commit would override the first.
2015-10-12 10:50:28 -07:00

172 lines
4.4 KiB
Go

package dataset
import (
"testing"
"github.com/attic-labs/noms/Godeps/_workspace/src/github.com/stretchr/testify/assert"
"github.com/attic-labs/noms/chunks"
"github.com/attic-labs/noms/datas"
"github.com/attic-labs/noms/types"
)
func TestDatasetCommitTracker(t *testing.T) {
assert := assert.New(t)
id1 := "testdataset"
id2 := "othertestdataset"
ms := chunks.NewMemoryStore()
ds1 := NewDataset(datas.NewDataStore(ms), id1)
ds1Commit := types.NewString("Commit value for " + id1)
ds1, ok := ds1.Commit(ds1Commit)
assert.True(ok)
ds2 := NewDataset(datas.NewDataStore(ms), id2)
ds2Commit := types.NewString("Commit value for " + id2)
ds2, ok = ds2.Commit(ds2Commit)
assert.True(ok)
assert.EqualValues(ds1Commit, ds1.Head().Value())
assert.EqualValues(ds2Commit, ds2.Head().Value())
assert.False(ds2.Head().Value().Equals(ds1Commit))
assert.False(ds1.Head().Value().Equals(ds2Commit))
assert.Equal("sha1-018203db5f23522729c1b3a2e9afc785553000dc", ms.Root().String())
}
func TestExplicitBranchUsingDatasets(t *testing.T) {
assert := assert.New(t)
id1 := "testdataset"
id2 := "othertestdataset"
ms := chunks.NewMemoryStore()
getDS := func(id string) Dataset {
store := datas.NewDataStore(ms)
return NewDataset(store, id)
}
ds1 := getDS(id1)
// ds1: |a|
a := types.NewString("a")
ds1, ok := ds1.Commit(a)
assert.True(ok)
assert.True(ds1.Head().Value().Equals(a))
// ds1: |a|
// \ds2
ds2 := getDS(id2)
ds2, ok = ds2.Commit(ds1.Head().Value())
assert.True(ok)
assert.True(ds2.Head().Value().Equals(a))
// ds1: |a| <- |b|
b := types.NewString("b")
ds1, ok = ds1.Commit(b)
assert.False(ok)
assert.True(ds1.Head().Value().Equals(a))
// Commit failed, but ds1 didn't change, so we should be able to just try again.
ds1, ok = ds1.Commit(b)
assert.True(ok)
assert.True(ds1.Head().Value().Equals(b))
// ds1: |a| <- |b|
// \ds2 <- |c|
c := types.NewString("c")
ds2, ok = ds2.Commit(c)
assert.False(ok)
assert.True(ds2.Head().Value().Equals(a))
// Commit failed, but ds2 didn't change, so we should be able to just try again.
ds2, ok = ds2.Commit(c)
assert.True(ok)
assert.True(ds2.Head().Value().Equals(c))
// ds1: |a| <- |b| <--|d|
// \ds2 <- |c| <--/
mergeParents := datas.NewSetOfCommit().Insert(ds1.Head()).Insert(ds2.Head())
d := types.NewString("d")
ds2, ok = ds2.CommitWithParents(d, mergeParents)
assert.True(ok)
assert.True(ds2.Head().Value().Equals(d))
ds1, ok = ds1.CommitWithParents(d, mergeParents)
assert.False(ok)
assert.True(ds1.Head().Value().Equals(b))
// Commit failed, but while ds2 changed, ds1 didn't.
ds1, ok = ds1.CommitWithParents(d, mergeParents)
assert.True(ok)
assert.True(ds1.Head().Value().Equals(d))
}
func TestTwoClientsWithEmptyDataset(t *testing.T) {
assert := assert.New(t)
id1 := "testdataset"
ms := chunks.NewMemoryStore()
getDS := func(id string) Dataset {
store := datas.NewDataStore(ms)
return NewDataset(store, id)
}
dsx := getDS(id1)
dsy := getDS(id1)
// dsx: || -> |a|
a := types.NewString("a")
dsx, ok := dsx.Commit(a)
assert.True(ok)
assert.True(dsx.Head().Value().Equals(a))
// dsy: || -> |b|
_, ok = dsy.MaybeHead()
assert.False(ok)
b := types.NewString("b")
dsy, ok = dsy.Commit(b)
assert.False(ok)
// Commit failed, but ds1 now has latest head, so we should be able to just try again.
// dsy: |a| -> |b|
dsy, ok = dsy.Commit(b)
assert.True(ok)
assert.True(dsy.Head().Value().Equals(b))
}
func TestTwoClientsWithNonEmptyDataset(t *testing.T) {
assert := assert.New(t)
id1 := "testdataset"
ms := chunks.NewMemoryStore()
getDS := func(id string) Dataset {
store := datas.NewDataStore(ms)
return NewDataset(store, id)
}
a := types.NewString("a")
{
// ds1: || -> |a|
ds1 := getDS(id1)
ds1, ok := ds1.Commit(a)
assert.True(ok)
assert.True(ds1.Head().Value().Equals(a))
}
dsx := getDS(id1)
dsy := getDS(id1)
// dsx: |a| -> |b|
assert.True(dsx.Head().Value().Equals(a))
b := types.NewString("b")
dsx, ok := dsx.Commit(b)
assert.True(ok)
assert.True(dsx.Head().Value().Equals(b))
// dsy: |a| -> |c|
assert.True(dsy.Head().Value().Equals(a))
c := types.NewString("c")
dsy, ok = dsy.Commit(c)
assert.False(ok)
assert.True(dsy.Head().Value().Equals(b))
// Commit failed, but dsy now has latest head, so we should be able to just try again.
// dsy: |b| -> |c|
dsy, ok = dsy.Commit(c)
assert.True(ok)
assert.True(dsy.Head().Value().Equals(c))
}