Skip to content

Commit

Permalink
test: fix validator tests never fail (#42)
Browse files Browse the repository at this point in the history
  • Loading branch information
stevoland authored May 20, 2024
2 parents 8c91ba5 + fc9bfee commit 5f631db
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 54 deletions.
17 changes: 17 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -120,6 +120,23 @@ overridevalidators:
A sample of `deployment-settings` file is found [here](docs/sample-settings/sample-deployment-settings.yml).

#### Specific validation messages

Validators can also throw errors rather than returning `false` in order to provide specific messages:

```yaml
configvalidators:
- plugin: collaborators
error: |
`Invalid collaborators config`
script: |
if (baseconfig.permission == 'admin') {
throw new Error(`collaborator permission: admin not allowed`)
}
return true
```
### Performance
When there are 1000s of repos to be managed -- and there is a global settings change -- safe-settings will have to work efficiently and only make the necessary API calls.
Expand Down
71 changes: 17 additions & 54 deletions test/unit/lib/validator.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,15 +16,9 @@ describe('Validator Tests', () => {
return overrideconfig.protection.required_pull_request_reviews.required_approving_review_count >= baseconfig.protection.required_pull_request_reviews.required_approving_review_count
}
return true

// console.log(`Branch override validator, baseconfig ${baseconfig} overrideconfig ${overrideconfig}`)
// return false
})

const configMock = jest.fn((baseconfig) => {
console.log(`Branch config validator, baseconfig ${baseconfig}`)
return false
})
const configMock = jest.fn((baseconfig) => false)
DeploymentConfig.overridevalidators = { branches: { canOverride: overrideMock, error: 'Branch overrideValidators.error' } }
DeploymentConfig.configvalidators = { branches: { isValid: configMock, error: 'Branch configValidators.error' } }

Expand Down Expand Up @@ -58,30 +52,17 @@ describe('Validator Tests', () => {
enforce_admins: false
`)

try {
const ignorableFields = []
const mergeDeep = new MergeDeep(log, {}, ignorableFields)
mergeDeep.mergeDeep(baseconfig, overrideconfig)
// const merged = mergeDeep.mergeDeep(baseconfig, overrideconfig)
// expect(() => mergeDeep.mergeDeep(baseconfig, overrideconfig)).toThrow('you are using the wrong JDK');
} catch (err) {
expect(err).toBeDefined()
console.log(JSON.stringify(err))
expect(err).toEqual(Error('Branch overrideValidators.error'))
}
const ignorableFields = []
const mergeDeep = new MergeDeep(log, {}, ignorableFields)

expect(() => mergeDeep.mergeDeep(baseconfig, overrideconfig)).toThrow('Branch overrideValidators.error')
expect(overrideMock.mock.calls.length).toBe(1)
})

it('Repository override validator test', () => {
const overrideMock = jest.fn((baseconfig, overrideconfig) => {
console.log(`Repo override validator, baseconfig ${baseconfig} overrideconfig ${overrideconfig}`)
return false
})
const overrideMock = jest.fn(() => false)

const configMock = jest.fn((baseconfig) => {
console.log(`Repo config validator, baseconfig ${baseconfig}`)
return false
})
const configMock = jest.fn(() => false)
DeploymentConfig.overridevalidators = { repository: { canOverride: overrideMock, error: 'Repo overrideValidators.error' } }
DeploymentConfig.configvalidators = { repository: { isValid: configMock, error: 'Repo configValidators.error' } }

Expand Down Expand Up @@ -116,27 +97,16 @@ describe('Validator Tests', () => {
- newone
`)

try {
const ignorableFields = []
const mergeDeep = new MergeDeep(log, {}, ignorableFields)
mergeDeep.mergeDeep(baseconfig, overrideconfig)
} catch (err) {
expect(err).toBeDefined()
expect(err).toEqual(Error('Repo overrideValidators.error'))
}
const ignorableFields = []
const mergeDeep = new MergeDeep(log, {}, ignorableFields)
expect(() => mergeDeep.mergeDeep(baseconfig, overrideconfig)).toThrow('Repo overrideValidators.error')
expect(overrideMock.mock.calls.length).toBe(1)
})

it('Repository config validator test', () => {
const overrideMock = jest.fn((baseconfig, overrideconfig) => {
console.log(`Repo override validator, baseconfig ${baseconfig} overrideconfig ${overrideconfig}`)
return true
})
const overrideMock = jest.fn(() => true)

const configMock = jest.fn((baseconfig) => {
console.log(`Repo config validator, baseconfig ${baseconfig}`)
return false
})
const configMock = jest.fn(() => false)
DeploymentConfig.overridevalidators = { repository: { canOverride: overrideMock, error: 'Repo overrideValidators.error' } }
DeploymentConfig.configvalidators = { repository: { isValid: configMock, error: 'Repo configValidators.error' } }

Expand Down Expand Up @@ -171,14 +141,10 @@ describe('Validator Tests', () => {
- newone
`)

try {
const ignorableFields = []
const mergeDeep = new MergeDeep(log, ignorableFields)
mergeDeep.mergeDeep(baseconfig, overrideconfig)
} catch (err) {
expect(err).toBeDefined()
expect(err).toEqual(Error('Repo configValidators.error'))
}
const ignorableFields = []
const mergeDeep = new MergeDeep(log, {}, ignorableFields)

expect(() => mergeDeep.mergeDeep(baseconfig, overrideconfig)).toThrow('Repo configValidators.error')
expect(configMock.mock.calls.length).toBe(1)
})

Expand All @@ -187,10 +153,7 @@ describe('Validator Tests', () => {
throw new Error('Custom message')
})

const configMock = jest.fn((baseconfig) => {
console.log(`Branch config validator, baseconfig ${baseconfig}`)
return false
})
const configMock = jest.fn(() => false)
DeploymentConfig.overridevalidators = { branches: { canOverride: overrideMock, error: 'Branch overrideValidators.error' } }
DeploymentConfig.configvalidators = { branches: { isValid: configMock, error: 'Branch configValidators.error' } }

Expand Down

0 comments on commit 5f631db

Please sign in to comment.