1
0
Fork 0
freesewing/tests/designs/sampling.mjs

127 lines
3.4 KiB
JavaScript
Raw Normal View History

2022-08-27 09:27:35 +02:00
import designs from "../../config/software/designs.json" assert { type: 'json' }
import { nonHumanMeasurements } from './non-human-measurements.mjs'
2022-08-25 12:53:07 +02:00
import { withBreasts, withoutBreasts } from '@freesewing/models'
2022-08-27 09:27:35 +02:00
import { getShortName, getFamily } from './config.mjs'
2022-08-25 11:52:34 +02:00
import chai from 'chai'
const expect = chai.expect
2022-08-27 09:27:35 +02:00
const models = { withBreasts, withoutBreasts }
// Some patterns are deprecated and won't support more stringent doll/giant tests
const deprecated = ['theo']
/*
* This runs unit tests for pattern sampling
* It expects the following:
*
2022-08-27 09:27:35 +02:00
* @param object Pattern: Pattern constructor
2022-08-25 11:52:34 +02:00
* @param boolean log: Set to true to log errors
*/
2022-08-27 09:27:35 +02:00
export const testPatternSampling = (Pattern, log=false) => {
2021-09-12 14:03:25 +02:00
2022-08-27 09:27:35 +02:00
const pattern = new Pattern()
const config = pattern.getConfig()
const design = getShortName(config.name)
const family = getFamily(design)
const parts = pattern.getPartList()
2021-09-12 14:03:25 +02:00
// Load non-human measurements
const nonHuman = nonHumanMeasurements(models)
// Helper method to try/catch pattern sampling
const doesItSample = (pattern, log=false) => {
try {
pattern.sample()
if (pattern.events.error.length < 1) return true
if (log) console.log(pattern.events.error)
return false
}
catch (err) {
if (log) console.log(err)
return false
}
}
2022-08-25 11:52:34 +02:00
// FIXME: Always use breasts for now
const breasts = true
const ourModels = models
[breasts ? 'withBreasts' : 'withoutBreasts']
const measurements = ourModels
[breasts ? 'size34' : 'size42']
if (['rendertest', 'tutorial', 'examples'].indexOf(design) === -1) {
/*
* Sample different measurements
*/
it('Sample different measurements:' , () => true)
for (let measurement of Pattern.config.measurements || []) {
it(` Sample ${measurement}:` , () => {
expect(doesItSample(new Pattern({
sample: {
type: 'measurement',
measurement
},
measurements
2022-06-30 12:09:35 +02:00
}), log)).to.equal(true)
})
}
}
if (['rendertest', 'tutorial', 'examples'].indexOf(design) === -1) {
/*
* Sample different options
*/
it('Sample different options:' , () => true)
for (let option in Pattern.config.options) {
2022-06-30 12:09:35 +02:00
if (typeof Pattern.config.options[option] === 'object') {
it(` Sample ${option}:` , () => {
expect(doesItSample(new Pattern({
sample: {
type: 'option',
option
},
measurements
2022-06-30 12:09:35 +02:00
}), log)).to.equal(true)
})
2022-06-30 12:09:35 +02:00
}
}
}
if (['rendertest', 'tutorial', 'examples'].indexOf(design) === -1) {
/*
* Sample pattern for different models
*/
it('Sample pattern for size range:' , () => {
expect(doesItSample(new Pattern({
sample: {
type: 'models',
models: ourModels,
},
measurements
2022-06-30 12:09:35 +02:00
}), log)).to.equal(true)
})
}
if (['rendertest', 'tutorial', 'examples'].indexOf(design) === -1) {
2021-09-12 14:03:25 +02:00
if (deprecated.indexOf(design) === -1) {
/*
* Sample pattern for dolls & giants
*/
for (const type of ['dolls', 'giants']) {
it(`Sample pattern for ${type}:` , () => {
expect(doesItSample(new Pattern({
sample: {
type: 'models',
models: nonHuman[breasts ? 'withBreasts' : 'withoutBreasts'][type]
},
measurements
2022-06-30 12:09:35 +02:00
}), log)).to.equal(true)
2021-09-12 14:03:25 +02:00
})
}
}
}
}