@cosmology/ast
Version:
Cosmos TypeScript AST generation
46 lines (44 loc) • 1.78 kB
JavaScript
import { createAggregatedLCDClient } from '../class';
import { traverse } from '@cosmology/proto-parser';
import { getNestedProto } from '@cosmology/utils';
import { defaultTelescopeOptions } from '@cosmology/types';
import generate from '@babel/generator';
import { GenericParseContext } from '../../../encoding';
import { getTestProtoStore } from '../../../../test-utils';
const store = getTestProtoStore();
store.traverseAll();
const expectCode = ast => {
expect(generate(ast).code).toMatchSnapshot();
};
const printCode = ast => {
console.log(generate(ast).code);
};
it('AggregatedLCDClient', () => {
const ref1 = store.findProto('cosmos/bank/v1beta1/query.proto');
const ref2 = store.findProto('osmosis/gamm/v1beta1/query.proto');
const res1 = traverse(store, ref1);
const res2 = traverse(store, ref2);
const service1 = getNestedProto(res1).Query;
const service2 = getNestedProto(res2).Query;
const context = new GenericParseContext(ref1, store, defaultTelescopeOptions);
const ast = createAggregatedLCDClient(context, [service1, service2], 'QueryClient');
expectCode(ast);
});
// TODO - use package names to shape the class
// e.g. osmosis.gamm.v1beta1.pools()
it('options', () => {
const packages = ['cosmos.bank.v1beta1', 'osmosis.gamm.v1beta1'];
const refs = store.filterProtoWhere(ref => {
return packages.includes(ref.proto.package);
});
const services = refs.map(ref => {
const proto = getNestedProto(ref.traversed);
if (!proto?.Query || proto.Query?.type !== 'Service') {
return;
}
return proto.Query;
}).filter(Boolean);
const context = new GenericParseContext(refs[0], store, defaultTelescopeOptions);
const ast = createAggregatedLCDClient(context, services, 'QueryClient');
expectCode(ast);
});