insomnia/app/common/__tests__/render.test.js

171 lines
3.9 KiB
JavaScript
Raw Normal View History

import * as renderUtils from '../render';
2016-11-10 05:56:23 +00:00
import * as models from '../../models';
jest.mock('electron');
describe('render()', () => {
it('renders hello world', () => {
const rendered = renderUtils.render('Hello {{ msg }}!', {msg: 'World'});
expect(rendered).toBe('Hello World!');
});
it('renders custom tag: uuid', () => {
const rendered = renderUtils.render('Hello {% uuid %}!');
Sync Proof of Concept (#33) * Maybe working POC * Change to use remote url * Other URL too * Some logic * Got the push part working * Made some updates * Fix * Update * Add status code check * Stuff * Implemented new sync api * A bit more robust * Debounce changes * Change timeout * Some fixes * Remove .less * Better error handling * Fix base url * Support for created vs updated docs * Try silent * Silence removal too * Small fix after merge * Fix test * Stuff * Implement key generation algorithm * Tidy * stuff * A bunch of stuff for the new API * Integrated the session stuff * Stuff * Just started on encryption * Lots of updates to encryption * Finished createResourceGroup function * Full encryption/decryption working (I think) * Encrypt localstorage with sessionID * Some more * Some extra checks * Now uses separate DB. Still needs to be simplified a LOT * Fix deletion bug * Fixed unicode bug with encryption * Simplified and working * A bunch of polish * Some stuff * Removed some workspace meta properties * Migrated a few more meta properties * Small changes * Fix body scrolling and url cursor jumping * Removed duplication of webpack port * Remove workspaces reduces * Some small fixes * Added sync modal and opt-in setting * Good start to sync flow * Refactored modal footer css * Update sync status * Sync logger * A bit better logging * Fixed a bunch of sync-related bugs * Fixed signup form button * Gravatar component * Split sync modal into tabs * Tidying * Some more error handling * start sending 'user agent * Login/signup error handling * Use real UUIDs * Fixed tests * Remove unused function * Some extra checks * Moved cloud sync setting to about page * Some small changes * Some things
2016-10-21 17:20:36 +00:00
expect(rendered).toMatch(/Hello [a-z0-9]{8}-[a-z0-9]{4}-[a-z0-9]{4}-[a-z0-9]{4}-[a-z0-9]{12}!/);
});
it('renders custom tag: timestamp', () => {
const rendered = renderUtils.render('Hello {% timestamp %}!');
expect(rendered).toMatch(/Hello \d{13}!/);
});
it('fails on invalid template', () => {
const fn = () => renderUtils.render('Hello {{ msg }!', {msg: 'World'});
expect(fn).toThrowError('expected variable end');
});
});
describe('buildRenderContext()', () => {
it('cascades properly', () => {
const ancestors = [{
2016-11-10 01:15:27 +00:00
type: models.requestGroup.type,
environment: {foo: 'group 2', ancestor: true}
}, {
2016-11-10 01:15:27 +00:00
type: models.requestGroup.type,
environment: {foo: 'group 1', ancestor: true}
}];
const rootEnvironment = {
2016-11-10 01:15:27 +00:00
type: models.environment.type,
data: {foo: 'root', root: true}
};
const subEnvironment = {
2016-11-10 01:15:27 +00:00
type: models.environment.type,
data: {foo: 'sub', sub: true}
};
const context = renderUtils.buildRenderContext(
ancestors,
rootEnvironment,
subEnvironment
);
expect(context).toEqual({
foo: 'group 1',
ancestor: true,
root: true,
sub: true
});
});
2016-09-12 21:16:55 +00:00
it('cascades properly and renders', () => {
const ancestors = [{
2016-11-10 01:15:27 +00:00
type: models.requestGroup.type,
2016-09-12 21:16:55 +00:00
environment: {bar: '{{ foo }} 2', recursive: '{{ recursive }}', ancestor: true}
}, {
2016-11-10 01:15:27 +00:00
type: models.requestGroup.type,
2016-09-12 21:16:55 +00:00
environment: {bar: '{{ foo }} 1', ancestor: true}
}];
const rootEnvironment = {
2016-11-10 01:15:27 +00:00
type: models.environment.type,
2016-09-12 21:16:55 +00:00
data: {foo: 'root', root: true}
};
const subEnvironment = {
2016-11-10 01:15:27 +00:00
type: models.environment.type,
2016-09-12 21:16:55 +00:00
data: {foo: 'sub', sub: true}
};
const context = renderUtils.buildRenderContext(
2016-09-12 21:16:55 +00:00
ancestors,
rootEnvironment,
subEnvironment
);
expect(context).toEqual({
foo: 'sub',
bar: 'sub 1',
recursive: '{{ recursive }}',
ancestor: true,
root: true,
sub: true
});
});
it('works with minimal parameters', () => {
const ancestors = null;
const rootEnvironment = null;
const subEnvironment = null;
const context = renderUtils.buildRenderContext(
ancestors,
rootEnvironment,
subEnvironment
);
expect(context).toEqual({});
});
});
describe('recursiveRender()', () => {
it('correctly renders simple Object', () => {
const newObj = renderUtils.recursiveRender({
foo: '{{ foo }}',
bar: 'bar',
baz: '{{ bad }}'
}, {foo: 'bar'});
expect(newObj).toEqual({
foo: 'bar',
bar: 'bar',
baz: ''
})
});
it('correctly renders complex Object', () => {
const d = new Date();
2016-09-06 16:14:48 +00:00
const obj = {
foo: '{{ foo }}',
null: null,
bool: true,
date: d,
num: 1234,
nested: {
foo: '{{ foo }}',
arr: [1,2, '{{ foo }}']
}
2016-09-06 16:14:48 +00:00
};
const newObj = renderUtils.recursiveRender(obj, {foo: 'bar'});
expect(newObj).toEqual({
foo: 'bar',
null: null,
bool: true,
date: d,
num: 1234,
nested: {
foo: 'bar',
arr: [1,2, 'bar']
}
2016-09-06 16:14:48 +00:00
});
// Make sure original request isn't changed
expect(obj.foo).toBe('{{ foo }}');
expect(obj.nested.foo).toBe('{{ foo }}');
expect(obj.nested.arr[2]).toBe('{{ foo }}');
});
it('fails on bad template', () => {
const fn = () => renderUtils.recursiveRender({
foo: '{{ foo }',
bar: 'bar',
baz: '{{ bad }}'
}, {foo: 'bar'});
expect(fn).toThrowError('expected variable end');
})
});