summaryrefslogtreecommitdiffstats
path: root/tests/feed-atom.spec.js
blob: 7a26a600ada15b5a041e77c2e911d4d27a52b802 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
'use strict';

// @ts-check
const { test, expect } = require('@playwright/test');
const jsdom = require('jsdom');
const { JSDOM } = jsdom;

test('atom feed has correct updated field', async ({ page }) => {
  await page.goto('/atom.xml');

  // Get the content of the page
  const content = await page.content();

  // Create a new JSDOM instance
  const dom = new JSDOM(content, { contentType: 'text/xml' });

  // Get the global window object
  const { window } = dom;

  // Get the updated field
  const updatedField = window.document.querySelector('feed > updated');

  // Check if the updated field exists
  expect(updatedField).not.toBeNull();

  // Check if the updated field is not empty
  expect(updatedField.textContent).not.toBe('');

  // Check if the updated field has the correct format
  const dateRegex = /^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}(?:Z|[+-]\d{2}:\d{2})$/;
  expect(updatedField.textContent).toMatch(dateRegex);
});

test('atom feed has correct author information', async ({ page }) => {
  await page.goto('/atom.xml');

  // Get the content of the page
  const content = await page.content();

  // Create a new JSDOM instance
  const dom = new JSDOM(content, { contentType: 'text/xml' });

  // Get the global window object
  const { window } = dom;

  // Get the author element
  const authorElement = window.document.querySelector('feed > author');

  // Check if the author element exists
  expect(authorElement).not.toBeNull();

  // Get the name element
  const nameElement = authorElement.querySelector('name');

  // Check if the name element exists
  expect(nameElement).not.toBeNull();

  // Check if the name element has the correct text content
  expect(nameElement.textContent).not.toBeNull();
  expect(nameElement.textContent.trim()).not.toBe('');

  // Get the email element
  const emailElement = authorElement.querySelector('email');

  // Check if the email element exists
  expect(emailElement).not.toBeNull();

  // Check if the email element has the correct text content
  expect(emailElement.textContent).not.toBeNull();
  expect(emailElement.textContent.trim()).not.toBe('');
});

test('atom feed entries have correct published and updated fields', async ({ page }) => {
  await page.goto('/atom.xml');

  // Get the content of the page
  const content = await page.content();

  // Create a new JSDOM instance
  const dom = new JSDOM(content, { contentType: 'text/xml' });

  // Get the global window object
  const { window } = dom;

  // Get all entry elements
  const entries = window.document.querySelectorAll('feed > entry');

  // Regex to match RFC 3339 date-time format
  const rfc3339Regex = /^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}(?:Z|[+-]\d{2}:\d{2})$/;

  entries.forEach(entry => {
    const publishedField = entry.querySelector('published');

    // Check if the published field
    // - exists
    // - not empty
    // - has the correct format
    expect(publishedField).not.toBeNull();
    expect(publishedField.textContent).not.toBe('');
    expect(publishedField.textContent).toMatch(rfc3339Regex);

    const updatedField = entry.querySelector('updated');

    // Check if the updated field
    // - exists
    // - not empty
    // - has the correct format
    expect(updatedField).not.toBeNull();
    expect(updatedField.textContent).not.toBe('');
    expect(updatedField.textContent).toMatch(rfc3339Regex);
  });
});