Skip to content

Commit

Permalink
fix: default filter not applied for empty array
Browse files Browse the repository at this point in the history
  • Loading branch information
harttle committed Mar 25, 2020
1 parent 94d67d2 commit c371762
Show file tree
Hide file tree
Showing 5 changed files with 22 additions and 28 deletions.
10 changes: 0 additions & 10 deletions home.html

This file was deleted.

2 changes: 1 addition & 1 deletion src/builtin/filters/html.ts
Expand Up @@ -28,7 +28,7 @@ export function escapeOnce (str: string) {
}

export function newlineToBr (v: string) {
return v.replace(/\n/g, '<br />')
return v.replace(/\n/g, '<br/>')
}

export function stripHtml (v: string) {
Expand Down
5 changes: 3 additions & 2 deletions src/builtin/filters/object.ts
@@ -1,8 +1,9 @@
import { isFalsy } from '../../render/boolean'
import { toValue } from '../../util/underscore'
import { isArray, isString, toValue } from '../../util/underscore'

export function Default<T1, T2> (v: string | T1, arg: T2): string | T1 | T2 {
return isFalsy(toValue(v)) || v === '' ? arg : v
if (isArray(v) || isString(v)) return v.length ? v : arg
return isFalsy(toValue(v)) ? arg : v
}
export function json (v: any) {
return JSON.stringify(v)
Expand Down
6 changes: 3 additions & 3 deletions test/integration/builtin/filters/html.ts
Expand Up @@ -29,9 +29,9 @@ describe('filters/html', function () {
'there\n' +
'{% endcapture %}' +
'{{ string_with_newlines | newline_to_br }}'
const dst = '<br />' +
'Hello<br />' +
'there<br />'
const dst = '<br/>' +
'Hello<br/>' +
'there<br/>'
return test(src, dst)
})
})
Expand Down
27 changes: 15 additions & 12 deletions test/integration/builtin/filters/object.ts
@@ -1,19 +1,22 @@
import { test } from '../../../stub/render'
import { Liquid } from '../../../../src/liquid'
import { expect } from 'chai'

describe('filters/object', function () {
const liquid = new Liquid()
describe('default', function () {
it('false should use default', () => test('{{false | default: "a"}}', 'a'))
it('empty string should use default', () => test('{{"" | default: "a"}}', 'a'))
it('non-empty string should not use default', () => test('{{" " | default: "a"}}', ' '))
it('nil should use default', () => test('{{nil | default: "a"}}', 'a'))
it('undefined should use default', () => test('{{not_defined | default: "a"}}', 'a'))
it('true should not use default', () => test('{{true | default: "a"}}', 'true'))
it('0 should not use default', () => test('{{0 | default: "a"}}', '0'))
it('false should use default', async () => expect(await liquid.parseAndRender('{{false | default: "a"}}')).to.equal('a'))
it('empty string should use default', async () => expect(await liquid.parseAndRender('{{"" | default: "a"}}')).to.equal('a'))
it('empty array should use default', async () => expect(await liquid.parseAndRender('{{arr | default: "a"}}', { arr: [] })).to.equal('a'))
it('non-empty string should not use default', async () => expect(await liquid.parseAndRender('{{" " | default: "a"}}')).to.equal(' '))
it('nil should use default', async () => expect(await liquid.parseAndRender('{{nil | default: "a"}}')).to.equal('a'))
it('undefined should use default', async () => expect(await liquid.parseAndRender('{{not_defined | default: "a"}}')).to.equal('a'))
it('true should not use default', async () => expect(await liquid.parseAndRender('{{true | default: "a"}}')).to.equal('true'))
it('0 should not use default', async () => expect(await liquid.parseAndRender('{{0 | default: "a"}}')).to.equal('0'))
})
describe('json', function () {
it('should stringify string', () => test('{{"foo" | json}}', '"foo"'))
it('should stringify number', () => test('{{2 | json}}', '2'))
it('should stringify object', () => test('{{obj | json}}', '{"foo":"bar"}'))
it('should stringify array', () => test('{{arr | json}}', '[-2,"a"]'))
it('should stringify string', async () => expect(await liquid.parseAndRender('{{"foo" | json}}')).to.equal('"foo"'))
it('should stringify number', async () => expect(await liquid.parseAndRender('{{2 | json}}')).to.equal('2'))
it('should stringify object', async () => expect(await liquid.parseAndRender('{{obj | json}}', { obj: { foo: 'bar' } })).to.equal('{"foo":"bar"}'))
it('should stringify array', async () => expect(await liquid.parseAndRender('{{arr | json}}', { arr: [-2, 'a'] })).to.equal('[-2,"a"]'))
})
})

0 comments on commit c371762

Please sign in to comment.