mirror of
https://github.com/jzillmann/pdf-to-markdown.git
synced 2024-11-22 07:43:46 +01:00
135 lines
5.1 KiB
JavaScript
135 lines
5.1 KiB
JavaScript
|
import { expect } from 'chai';
|
||
|
|
||
|
import HeadlineFinder from '../src/javascript/models/HeadlineFinder';
|
||
|
import TextItem from '../src/javascript/models/TextItem.jsx';
|
||
|
|
||
|
describe('HeadlineFinder', () => {
|
||
|
|
||
|
|
||
|
it('Not Found - Case 1', () => {
|
||
|
const headlineFinder = new HeadlineFinder({
|
||
|
headline: 'My Little Headline'
|
||
|
});
|
||
|
const item1 = new TextItem({
|
||
|
text: 'My '
|
||
|
});
|
||
|
const item2 = new TextItem({
|
||
|
text: 'Little'
|
||
|
});
|
||
|
const item3 = new TextItem({
|
||
|
text: ' Headline2'
|
||
|
});
|
||
|
|
||
|
expect(headlineFinder.consume(item1)).to.equal(null);
|
||
|
expect(headlineFinder.stackedTextItems).to.have.lengthOf(1).to.contain(item1);
|
||
|
expect(headlineFinder.consume(item2)).to.equal(null);
|
||
|
expect(headlineFinder.stackedTextItems).to.have.lengthOf(2).to.contain(item1).to.contain(item2);
|
||
|
expect(headlineFinder.consume(item3)).to.equal(null);
|
||
|
expect(headlineFinder.stackedTextItems).to.have.lengthOf(0);
|
||
|
|
||
|
});
|
||
|
|
||
|
it('Found - Simple', () => {
|
||
|
const headlineFinder = new HeadlineFinder({
|
||
|
headline: 'My Little Headline'
|
||
|
});
|
||
|
const item1 = new TextItem({
|
||
|
text: 'My '
|
||
|
});
|
||
|
const item2 = new TextItem({
|
||
|
text: 'Little'
|
||
|
});
|
||
|
const item3 = new TextItem({
|
||
|
text: ' Headline'
|
||
|
});
|
||
|
|
||
|
expect(headlineFinder.consume(item1)).to.equal(null);
|
||
|
expect(headlineFinder.stackedTextItems).to.have.lengthOf(1).to.contain(item1);
|
||
|
expect(headlineFinder.consume(item2)).to.equal(null);
|
||
|
expect(headlineFinder.stackedTextItems).to.have.lengthOf(2).to.contain(item1).to.contain(item2);
|
||
|
expect(headlineFinder.consume(item3)).to.have.lengthOf(3).to.contain(item1).to.contain(item2).to.contain(item3);
|
||
|
expect(headlineFinder.stackedTextItems).to.have.lengthOf(3).to.contain(item1).to.contain(item2).to.contain(item3);
|
||
|
|
||
|
});
|
||
|
|
||
|
it('Found - Waste in beginning', () => {
|
||
|
const headlineFinder = new HeadlineFinder({
|
||
|
headline: 'My Little Headline'
|
||
|
});
|
||
|
const item0 = new TextItem({
|
||
|
text: 'Waste '
|
||
|
});
|
||
|
const item1 = new TextItem({
|
||
|
text: 'My '
|
||
|
});
|
||
|
const item2 = new TextItem({
|
||
|
text: 'Little'
|
||
|
});
|
||
|
const item3 = new TextItem({
|
||
|
text: ' Headline'
|
||
|
});
|
||
|
|
||
|
expect(headlineFinder.consume(item0)).to.equal(null);
|
||
|
expect(headlineFinder.stackedTextItems).to.have.lengthOf(0);
|
||
|
expect(headlineFinder.consume(item1)).to.equal(null);
|
||
|
expect(headlineFinder.stackedTextItems).to.have.lengthOf(1).to.contain(item1);
|
||
|
expect(headlineFinder.consume(item2)).to.equal(null);
|
||
|
expect(headlineFinder.stackedTextItems).to.have.lengthOf(2).to.contain(item1).to.contain(item2);
|
||
|
expect(headlineFinder.consume(item3)).to.have.lengthOf(3).to.contain(item1).to.contain(item2).to.contain(item3);
|
||
|
expect(headlineFinder.stackedTextItems).to.have.lengthOf(3).to.contain(item1).to.contain(item2).to.contain(item3);
|
||
|
|
||
|
});
|
||
|
|
||
|
it('Found - Duplicate in beginning', () => {
|
||
|
const headlineFinder = new HeadlineFinder({
|
||
|
headline: 'My Little Headline'
|
||
|
});
|
||
|
const item0 = new TextItem({
|
||
|
text: 'My '
|
||
|
});
|
||
|
const item1 = new TextItem({
|
||
|
text: 'My '
|
||
|
});
|
||
|
const item2 = new TextItem({
|
||
|
text: 'Little'
|
||
|
});
|
||
|
const item3 = new TextItem({
|
||
|
text: ' Headline'
|
||
|
});
|
||
|
|
||
|
expect(headlineFinder.consume(item0)).to.equal(null);
|
||
|
expect(headlineFinder.stackedTextItems).to.have.lengthOf(1).to.contain(item0);
|
||
|
expect(headlineFinder.consume(item1)).to.equal(null);
|
||
|
expect(headlineFinder.stackedTextItems).to.have.lengthOf(1).to.contain(item1);
|
||
|
expect(headlineFinder.consume(item2)).to.equal(null);
|
||
|
expect(headlineFinder.stackedTextItems).to.have.lengthOf(2).to.contain(item1).to.contain(item2);
|
||
|
expect(headlineFinder.consume(item3)).to.have.lengthOf(3).to.contain(item1).to.contain(item2).to.contain(item3);
|
||
|
expect(headlineFinder.stackedTextItems).to.have.lengthOf(3).to.contain(item1).to.contain(item2).to.contain(item3);
|
||
|
|
||
|
});
|
||
|
|
||
|
it('Found - Mixed up case and Whitespace', () => {
|
||
|
const headlineFinder = new HeadlineFinder({
|
||
|
headline: 'MYLitt le HEADline'
|
||
|
});
|
||
|
const item1 = new TextItem({
|
||
|
text: 'My '
|
||
|
});
|
||
|
const item2 = new TextItem({
|
||
|
text: 'Little'
|
||
|
});
|
||
|
const item3 = new TextItem({
|
||
|
text: ' Headline'
|
||
|
});
|
||
|
|
||
|
expect(headlineFinder.consume(item1)).to.equal(null);
|
||
|
expect(headlineFinder.stackedTextItems).to.have.lengthOf(1).to.contain(item1);
|
||
|
expect(headlineFinder.consume(item2)).to.equal(null);
|
||
|
expect(headlineFinder.stackedTextItems).to.have.lengthOf(2).to.contain(item1).to.contain(item2);
|
||
|
expect(headlineFinder.consume(item3)).to.have.lengthOf(3).to.contain(item1).to.contain(item2).to.contain(item3);
|
||
|
expect(headlineFinder.stackedTextItems).to.have.lengthOf(3).to.contain(item1).to.contain(item2).to.contain(item3);
|
||
|
|
||
|
});
|
||
|
|
||
|
});
|