嗨伙计们!
我需要些帮助。我想用特定的结构测试我的服务树。
我的测试看起来是:
describe(`Service selector`, () => {
describe(`getCurrentServiceTree`, () => {
it(`should build the generic service tree`, () => {
const services = [
'{http://namespace-example.fr/service/technique/version/1.0}Localpart0',
'{http://namespace-example.fr/service/technique/version/1.0}Localpart1',
'{http://namespace-example.fr/service/technique/version/2.0}Localpart2',
'{http://namespace-example.fr/service/technique/version/3.0}Localpart3',
'{http://namespace-example.fr/service/technique/version/3.0}Localpart4',
];
const expectedTree: TreeElement<any>[] = [
{
name: 'http://namespace-example.fr/service/technique/version/1.0',
children: [
{
name: 'Localpart0',
children: [],
isFolded: false,
cssClass: 'item-localpart',
},
{
name: 'Localpart1',
children: [],
isFolded: false,
cssClass: 'item-localpart',
},
],
isFolded: false,
cssClass: 'item-namespace',
},
{
name: 'http://namespace-example.fr/service/technique/version/2.0',
children: [
{
name: 'Localpart2',
children: [],
isFolded: false,
cssClass: 'item-localpart',
},
],
isFolded: false,
cssClass: 'item-namespace',
},
{
name: 'http://namespace-example.fr/service/technique/version/3.0',
children: [
{
name: 'Localpart3',
children: [],
isFolded: false,
cssClass: 'item-localpart',
},
{
name: 'Localpart4',
children: [],
isFolded: false,
cssClass: 'item-localpart',
},
],
isFolded: false,
cssClass: 'item-namespace',
},
];
const generatedStore: Partial<IStore> = {
services: {
byId: services.reduce(
(acc, name, index) => ({ ...acc, [`service${index}`]: { name } }),
{}
),
allIds: services.map((_, index) => `service${index}`),
isFetchingServices: false,
selectedServiceId: '',
},
};
expect(getCurrentServiceTree(generatedStore as any)).toEqual(
expectedTree
);
});
});
});我不知道这是TypeScript问题还是与RxJS有关。或者只是我的代码:
当我把鼠标放到getCurrentServiceTree上时,我得到了这样的信息:
(别名) getCurrentServiceTree (状态: IStore):TreeElement[] import getCurrentServiceTree
我不知道我是否正确使用了Partial<T>。
我不能把generatedStore打成..。
当我把鼠标放进去的时候,我有:
=>任何‘n’- pas可归因于au paramètre de type 'IStore‘。La propriété'ui‘est manquante dans le type '() => any’
export const getCurrentServiceTree = createSelector(
getSelectedWorkspaceId,
getServicesAllIds,
getServicesById,
(selectedWorkspaceId, servicesAllIds, servicesByIds): TreeElement<any>[] => {
const baseUrl = `/workspaces/${selectedWorkspaceId}/services`;
const servicesWithNspLocalpart = servicesAllIds.map(id => ({
...findNamespaceLocalpart(servicesByIds[id].name),
id,
}));
const groupedByNamespace = groupByNamespace(servicesWithNspLocalpart);
return groupedByNamespace.map(nspWithLocalparts => ({
name: nspWithLocalparts.namespace,
isFolded: false,
cssClass: `item-namespace`,
link: ``,
children: nspWithLocalparts.localparts.map(localpart => ({
name: localpart.name,
isFolded: false,
cssClass: `item-localpart`,
link: `${baseUrl}/${localpart.id}`,
children: [],
})),
}));
}
);我该怎么做?
有人能解释一下我怎么解决我的问题吗?
发布于 2018-05-10 12:03:50
我今天也遇到了同样的错误。
现在还不清楚这个错误是从哪里来的。
我为调试所做的工作:
ng test (也可能是无头测试)运行您的测试,不要使用无头模式,也不要使用参数--no-sourcemaps启动它们。ng test不报告循环dep,但ng serve报告。https://stackoverflow.com/questions/48154330
复制相似问题