-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
refactor: entryモデルでゲッター/セッターを使わないように
- Loading branch information
Showing
17 changed files
with
180 additions
and
142 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,83 +1,116 @@ | ||
import { afterEach, describe, expect, it } from 'vitest'; | ||
import { DummyRepository } from '../adaptor/dummyRepository.js'; | ||
import { Entry, EntryID } from '../entry.js'; | ||
import { Result } from '@mikuroxina/mini-fn'; | ||
import { EntryService } from './entry.js'; | ||
import { TestEntryData } from '../../testData/entry.js'; | ||
import { SnowflakeIDGenerator } from '../../id/main.js'; | ||
import {afterEach, describe, expect, it} from 'vitest'; | ||
import {DummyRepository} from '../adaptor/dummyRepository.js'; | ||
import {Entry, EntryID} from '../entry.js'; | ||
import {Result} from '@mikuroxina/mini-fn'; | ||
import {EntryService} from './entry.js'; | ||
import {TestEntryData} from '../../testData/entry.js'; | ||
import {SnowflakeIDGenerator} from '../../id/main.js'; | ||
|
||
describe('entryService', () => { | ||
const repository = new DummyRepository(); | ||
const service = new EntryService( | ||
repository, | ||
new SnowflakeIDGenerator(1, () => BigInt(new Date().getTime())) | ||
); | ||
const repository = new DummyRepository(); | ||
const service = new EntryService( | ||
repository, | ||
new SnowflakeIDGenerator(1, () => BigInt(new Date().getTime())) | ||
); | ||
|
||
afterEach(() => { | ||
repository.reset(); | ||
}); | ||
|
||
it('エントリーできる', async () => { | ||
const actual = await service.create(TestEntryData['ElementaryMultiWalk']); | ||
afterEach(() => { | ||
repository.reset(); | ||
}); | ||
|
||
expect(Result.isOk(actual)).toBe(true); | ||
if (Result.isErr(actual)) { | ||
return; | ||
} | ||
it('エントリーできる', async () => { | ||
const data = TestEntryData['ElementaryMultiWalk']; | ||
const actual = await service.create({ | ||
teamName: data.getTeamName(), | ||
members: data.getMembers(), | ||
isMultiWalk: data.getIsMultiWalk(), | ||
category: data.getCategory(), | ||
}); | ||
|
||
expect(actual[1].members).toStrictEqual(['TestTaro1']); | ||
expect(actual[1].teamName).toBe('TestTeam1'); | ||
expect(actual[1].isMultiWalk).toBe(true); | ||
expect(actual[1].category).toBe('Elementary'); | ||
}); | ||
expect(Result.isOk(actual)).toBe(true); | ||
if (Result.isErr(actual)) { | ||
return; | ||
} | ||
|
||
it('チーム名が重複するときはエラー終了する', async () => { | ||
await service.create(TestEntryData['ElementaryMultiWalk']); | ||
const result = await service.create(TestEntryData['ElementaryMultiWalkExists']); | ||
expect(actual[1].getMembers()).toStrictEqual(['TestTaro1']); | ||
expect(actual[1].getTeamName()).toBe('TestTeam1'); | ||
expect(actual[1].getIsMultiWalk()).toBe(true); | ||
expect(actual[1].getCategory()).toBe('Elementary'); | ||
}); | ||
|
||
expect(Result.isErr(result)).toBe(true); | ||
expect(result[1]).toStrictEqual(new Error('teamName Exists')); | ||
}); | ||
it('チーム名が重複するときはエラー終了する', async () => { | ||
const data = TestEntryData['ElementaryMultiWalk']; | ||
const existsData = TestEntryData['ElementaryMultiWalkExists'] | ||
await service.create({ | ||
teamName: data.getTeamName(), | ||
members: data.getMembers(), | ||
isMultiWalk: data.getIsMultiWalk(), | ||
category: data.getCategory(), | ||
}); | ||
const result = await service.create({ | ||
teamName: existsData.getTeamName(), | ||
members: existsData.getMembers(), | ||
isMultiWalk: existsData.getIsMultiWalk(), | ||
category: existsData.getCategory() | ||
}); | ||
|
||
it('オープン部門のメンバーは1人のみ', async () => { | ||
const entry = Entry.new({ | ||
id: '123' as EntryID, | ||
teamName: 'team1', | ||
members: ['山田四十郎', '山田太郎'], | ||
isMultiWalk: true, | ||
category: 'Open', | ||
expect(Result.isErr(result)).toBe(true); | ||
expect(result[1]).toStrictEqual(new Error('teamName Exists')); | ||
}); | ||
const actual = await service.create(entry); | ||
|
||
expect(Result.isErr(actual)).toBe(true); | ||
expect(actual[1]).toStrictEqual(new Error('too many members')); | ||
}); | ||
it('オープン部門のメンバーは1人のみ', async () => { | ||
const entry = Entry.new({ | ||
id: '123' as EntryID, | ||
teamName: 'team1', | ||
members: ['山田四十郎', '山田太郎'], | ||
isMultiWalk: true, | ||
category: 'Open', | ||
}); | ||
const actual = await service.create({ | ||
teamName: entry.getTeamName(), | ||
members: entry.getMembers(), | ||
isMultiWalk: entry.getIsMultiWalk(), | ||
category: entry.getCategory(), | ||
}); | ||
|
||
it('小学生部門のメンバーは1または2人', async () => { | ||
const entry = Entry.new({ | ||
id: '123' as EntryID, | ||
teamName: 'team1', | ||
members: ['山田四十郎', '山田太郎', '山田次郎'], | ||
isMultiWalk: true, | ||
category: 'Elementary', | ||
expect(Result.isErr(actual)).toBe(true); | ||
expect(actual[1]).toStrictEqual(new Error('too many members')); | ||
}); | ||
const actual = await service.create(entry); | ||
|
||
expect(Result.isErr(actual)).toBe(true); | ||
expect(actual[1]).toStrictEqual(new Error('too many members')); | ||
}); | ||
it('小学生部門のメンバーは1または2人', async () => { | ||
const entry = Entry.new({ | ||
id: '123' as EntryID, | ||
teamName: 'team1', | ||
members: ['山田四十郎', '山田太郎', '山田次郎'], | ||
isMultiWalk: true, | ||
category: 'Elementary', | ||
}); | ||
const actual = await service.create({ | ||
teamName: entry.getTeamName(), | ||
members: entry.getMembers(), | ||
isMultiWalk: entry.getIsMultiWalk(), | ||
category: entry.getCategory(), | ||
}); | ||
|
||
it('メンバーが居ないチームは作れない', async () => { | ||
const entry = Entry.new({ | ||
id: '123' as EntryID, | ||
teamName: 'team1', | ||
members: [], | ||
isMultiWalk: true, | ||
category: 'Elementary', | ||
expect(Result.isErr(actual)).toBe(true); | ||
expect(actual[1]).toStrictEqual(new Error('too many members')); | ||
}); | ||
const actual = await service.create(entry); | ||
|
||
expect(Result.isErr(actual)).toBe(true); | ||
expect(actual[1]).toStrictEqual(new Error('no member')); | ||
}); | ||
it('メンバーが居ないチームは作れない', async () => { | ||
const entry = Entry.new({ | ||
id: '123' as EntryID, | ||
teamName: 'team1', | ||
members: [], | ||
isMultiWalk: true, | ||
category: 'Elementary', | ||
}); | ||
const actual = await service.create({ | ||
teamName: entry.getTeamName(), | ||
members: entry.getMembers(), | ||
isMultiWalk: entry.getIsMultiWalk(), | ||
category: entry.getCategory(), | ||
}); | ||
|
||
expect(Result.isErr(actual)).toBe(true); | ||
expect(actual[1]).toStrictEqual(new Error('no member')); | ||
}); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.