mon-entreprise/source/components/Mecanisms.js

57 lines
1.4 KiB
JavaScript
Raw Normal View History

// Page listing the engine's currently implemented mecanisms and their tests
import React, { Component } from 'react'
import knownMecanims from 'Engine/known-mecanisms.yaml'
2018-01-08 15:07:26 +00:00
import { fromPairs, has, toPairs } from 'ramda'
import './Mecanisms.css'
let directoryLoader = require.context('../../test/mécanismes/', true, /.yaml$/),
2018-01-08 15:07:26 +00:00
suites = fromPairs(
directoryLoader
.keys()
.map(key => [
key.replace(/\/|\.|(yaml)/g, '').replace(/-/g, ' '),
directoryLoader(key)
])
)
export default class Mecanisms extends Component {
render() {
return (
<div style={{ margin: '1em auto', maxWidth: '45em' }}>
<p>
Cette page liste les mécanismes et indique en rouge ceux qui n'ont pas
de tests. La commande "yarn test" permet de voir ceux qui passent. Ce
serait bien de pouvoir les faire tourner dans le navigateur en
partageant le code de mecanisms.test.js
</p>
<ul id="mecanisms">
2018-01-08 15:07:26 +00:00
{toPairs(knownMecanims).map(([name, data]) => (
<li key={name}>
{name}
{suites[name] == null ? (
<p className="warning">Pas de tests !</p>
) : (
<Tests name={name} suites={suites} />
)}
</li>
))}
</ul>
</div>
)
}
}
2017-11-30 10:05:25 +00:00
class Tests extends Component {
render() {
let { suites, name } = this.props,
suite = suites[name],
2018-01-08 15:07:26 +00:00
tests = suite.filter(has('test'))
2017-11-30 10:05:25 +00:00
return (
<p>
{tests.length} {tests.length == 1 ? 'test' : 'tests'}
</p>
)
}
}