summaryrefslogtreecommitdiff
path: root/db/seeds_2/userSeed.ts
diff options
context:
space:
mode:
Diffstat (limited to 'db/seeds_2/userSeed.ts')
-rw-r--r--db/seeds_2/userSeed.ts39
1 files changed, 39 insertions, 0 deletions
diff --git a/db/seeds_2/userSeed.ts b/db/seeds_2/userSeed.ts
new file mode 100644
index 00000000..c0258d5e
--- /dev/null
+++ b/db/seeds_2/userSeed.ts
@@ -0,0 +1,39 @@
+import db from "@/db/db"
+import { NewUser } from "@/lib/admin-users/repository"
+import { faker } from "@faker-js/faker"
+import { users } from "../schema/users"
+
+function generateRandomUser(): NewUser {
+ return {
+ name: faker.person.fullName(), // 또는 faker.company.name()
+ email: faker.internet.email(), // 필수 notNull 필드
+ domain: "evcp", // domain을 evcp로 고정
+ companyId: null, // companyId는 null로(빈칸)
+ imageUrl: null, // imageUrl은 null로(빈칸)
+ createdAt: faker.date.past() // 과거 임의 날짜
+ }
+}
+
+export async function seedUsers(input: { count: number }) {
+ try {
+ const allUsers: NewUser[] = []
+
+ for (let i = 0; i < input.count; i++) {
+ allUsers.push(generateRandomUser())
+ }
+
+ console.log("📝 Inserting users", allUsers.length)
+
+ // onConflictDoNothing을 사용하여 중복되는 데이터는 건너뛰고 새로운 데이터만 추가
+ const result = await db.insert(users)
+ .values(allUsers)
+ .onConflictDoNothing()
+ .returning()
+
+ console.log(`✅ Successfully added ${result.length} new users`)
+ return result
+ } catch (err) {
+ console.error("Failed to seed users:", err)
+ throw err
+ }
+}