commands: add platforms dedupe
Signed-off-by: Tonis Tiigi <tonistiigi@gmail.com>pull/31/head
parent
e773d0eb2a
commit
e40318e2cc
@ -0,0 +1,42 @@
|
|||||||
|
package store
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/require"
|
||||||
|
"github.com/tonistiigi/buildx/util/platformutil"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestNodeGroupUpdate(t *testing.T) {
|
||||||
|
t.Parallel()
|
||||||
|
|
||||||
|
ng := &NodeGroup{}
|
||||||
|
err := ng.Update("foo", "foo0", []string{"linux/amd64"}, true, false)
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
err = ng.Update("foo1", "foo1", []string{"linux/arm64", "linux/arm/v7"}, true, true)
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
require.Equal(t, len(ng.Nodes), 2)
|
||||||
|
|
||||||
|
// update
|
||||||
|
err = ng.Update("foo", "foo2", []string{"linux/amd64", "linux/arm"}, true, false)
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
require.Equal(t, len(ng.Nodes), 2)
|
||||||
|
require.Equal(t, []string{"linux/amd64", "linux/arm/v7"}, platformutil.Format(ng.Nodes[0].Platforms))
|
||||||
|
require.Equal(t, []string{"linux/arm64"}, platformutil.Format(ng.Nodes[1].Platforms))
|
||||||
|
|
||||||
|
require.Equal(t, "foo2", ng.Nodes[0].Endpoint)
|
||||||
|
|
||||||
|
// duplicate endpoint
|
||||||
|
err = ng.Update("foo1", "foo2", nil, true, false)
|
||||||
|
require.Error(t, err)
|
||||||
|
require.Contains(t, err.Error(), "duplicate endpoint")
|
||||||
|
|
||||||
|
err = ng.Leave("foo")
|
||||||
|
require.NoError(t, err)
|
||||||
|
|
||||||
|
require.Equal(t, len(ng.Nodes), 1)
|
||||||
|
require.Equal(t, []string{"linux/arm64"}, platformutil.Format(ng.Nodes[0].Platforms))
|
||||||
|
}
|
Loading…
Reference in New Issue