Files
ent/entc/integration/customid/customid_test.go
Ariel Mashraki 2b2e056f05 entc/gen/sql: support custom-id on create
Summary: Pull Request resolved: https://github.com/facebookincubator/ent/pull/166

Reviewed By: alexsn

Differential Revision: D18514295

fbshipit-source-id: e5988552c5611cbad18476ab2d9c2155df1e6e0c
2019-11-14 14:38:58 -08:00

35 lines
1.0 KiB
Go

// Copyright 2019-present Facebook Inc. All rights reserved.
// This source code is licensed under the Apache 2.0 license found
// in the LICENSE file in the root directory of this source tree.
package customid
import (
"context"
"testing"
"github.com/facebookincubator/ent/entc/integration/customid/ent"
_ "github.com/mattn/go-sqlite3"
"github.com/stretchr/testify/require"
)
func TestCustomID(t *testing.T) {
client, err := ent.Open("sqlite3", "file:ent?mode=memory&cache=shared&_fk=1")
require.NoError(t, err)
defer client.Close()
ctx := context.Background()
require.NoError(t, client.Schema.Create(ctx))
nat := client.User.Create().SaveX(ctx)
require.Equal(t, 1, nat.ID)
_, err = client.User.Create().SetID(1).Save(ctx)
require.True(t, ent.IsConstraintFailure(err), "duplicate id")
a8m := client.User.Create().SetID(5).SaveX(ctx)
require.Equal(t, 5, a8m.ID)
hub := client.Group.Create().SetID(3).AddUsers(a8m, nat).SaveX(ctx)
require.Equal(t, 3, hub.ID)
require.Equal(t, []int{1, 5}, hub.QueryUsers().IDsX(ctx))
}