Joe Chen 1 рік тому
батько
коміт
22526be6cf
1 змінених файлів з 28 додано та 0 видалено
  1. 28 0
      internal/db/organizations_test.go

+ 28 - 0
internal/db/organizations_test.go

@@ -50,6 +50,7 @@ func TestOrganizations(t *testing.T) {
 		{"RemoveMember", orgsRemoveMember},
 		{"RemoveMember", orgsRemoveMember},
 		{"HasMember", orgsHasMember},
 		{"HasMember", orgsHasMember},
 		{"ListMembers", orgsListMembers},
 		{"ListMembers", orgsListMembers},
+		{"IsOwnedBy", orgsIsOwnedBy},
 	} {
 	} {
 		t.Run(tc.name, func(t *testing.T) {
 		t.Run(tc.name, func(t *testing.T) {
 			t.Cleanup(func() {
 			t.Cleanup(func() {
@@ -595,3 +596,30 @@ func orgsListMembers(t *testing.T, db *organizations) {
 	assert.Equal(t, alice.ID, got[0].ID)
 	assert.Equal(t, alice.ID, got[0].ID)
 	assert.Equal(t, bob.ID, got[1].ID)
 	assert.Equal(t, bob.ID, got[1].ID)
 }
 }
+
+func orgsIsOwnedBy(t *testing.T, db *organizations) {
+	ctx := context.Background()
+
+	usersStore := NewUsersStore(db.DB)
+	alice, err := usersStore.Create(ctx, "alice", "alice@example.com", CreateUserOptions{})
+	require.NoError(t, err)
+	bob, err := usersStore.Create(ctx, "bob", "bob@exmaple.com", CreateUserOptions{})
+	require.NoError(t, err)
+	cindy, err := usersStore.Create(ctx, "cindy", "cindy@exmaple.com", CreateUserOptions{})
+	require.NoError(t, err)
+
+	tempPictureAvatarUploadPath := filepath.Join(os.TempDir(), "orgsListMembers-tempPictureAvatarUploadPath")
+	conf.SetMockPicture(t, conf.PictureOpts{AvatarUploadPath: tempPictureAvatarUploadPath})
+
+	org1, err := db.Create(ctx, "org1", alice.ID, CreateOrganizationOptions{})
+	require.NoError(t, err)
+	err = db.AddMember(ctx, org1.ID, bob.ID)
+	require.NoError(t, err)
+
+	got := db.IsOwnedBy(ctx, org1.ID, alice.ID)
+	assert.True(t, got)
+	got = db.IsOwnedBy(ctx, org1.ID, bob.ID)
+	assert.False(t, got)
+	got = db.IsOwnedBy(ctx, org1.ID, cindy.ID)
+	assert.False(t, got)
+}