Skip to content
Snippets Groups Projects
Select Git revision
  • 8b6d28074187a6ccadb5f5aed6e37264aabebe72
  • main default protected
  • renovate/main-vitest-monorepo
  • next
  • fix/36615b-branch-reuse-no-cache
  • chore/punycode
  • fix/36615-branch-reuse-bug
  • renovate/main-redis-5.x
  • renovate/main-xmldoc-2.x
  • refactor/pin-new-value
  • feat/36219--git-x509-signing
  • feat/structured-logger
  • hotfix/39.264.1
  • feat/skip-dangling
  • gh-readonly-queue/next/pr-36034-7a061c4ca1024a19e2c295d773d9642625d1c2be
  • hotfix/39.238.3
  • refactor/gitlab-auto-approve
  • feat/template-strings
  • gh-readonly-queue/next/pr-35654-137d934242c784e0c45d4b957362214f0eade1d7
  • fix/32307-global-extends-merging
  • fix/32307-global-extends-repositories
  • 41.11.1
  • 41.11.0
  • 41.10.1
  • 41.10.0
  • 41.9.0
  • 41.8.0
  • 41.7.2
  • 41.7.1
  • 41.7.0
  • 41.6.4
  • 41.6.3
  • 41.6.2
  • 41.6.1
  • 41.6.0
  • 41.5.0
  • 41.4.0
  • 41.3.0
  • 41.2.0
  • 41.1.4
  • 41.1.3
41 results

common.ts

Blame
  • html.spec.ts 1.24 KiB
    import * as parser from 'node-html-parser';
    import { parse } from './html';
    
    describe('util/html', () => {
      it('parses HTML', () => {
        const body = parse('<div>Hello, world!</div>');
        expect(body.childNodes).toHaveLength(1);
        const div = body.childNodes[0] as parser.HTMLElement;
        expect(div.tagName).toBe('DIV');
        expect(div.textContent).toBe('Hello, world!');
        expect(div instanceof parser.HTMLElement).toBeTrue();
      });
    
      it('returns empty', () => {
        const body = parse('');
        expect(body.childNodes).toHaveLength(0);
      });
    
      it('parses HTML: PRE block hides child nodes', () => {
        const body = parse('<div>Hello, world!</div>\n<pre><a>node A</a></pre>');
        const childNodesA = body.querySelectorAll('a');
        expect(childNodesA).toHaveLength(0);
      });
    
      it('parses HTML: use additional options to discover child nodes on PRE blocks', () => {
        const body = parse('<div>Hello, world!</div>\n<pre><a>node A</a></pre>', {
          blockTextElements: {},
        });
        const childNodesA = body.querySelectorAll('a');
        expect(childNodesA).toHaveLength(1);
        const div = childNodesA[0];
        expect(div.tagName).toBe('A');
        expect(div.textContent).toBe('node A');
        expect(div instanceof parser.HTMLElement).toBe(true);
      });
    });