Skip to content

Commit

Permalink
Add details to report
Browse files Browse the repository at this point in the history
  • Loading branch information
Brandon32 committed Sep 23, 2024
1 parent fdcdba0 commit 82cdb85
Show file tree
Hide file tree
Showing 3 changed files with 53 additions and 36 deletions.
7 changes: 7 additions & 0 deletions blocks/url-decode/url-decode.css
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@
.url-decode {
--error: #c9252d;

font-size: 14px;
margin: 0 auto 40px;
padding: 20px;
Expand All @@ -16,6 +18,11 @@
margin-bottom: 20px;
}

.url-decode .ribbon .error {
color: var(--error);
font-weight: bold;
}

.url-decode .options label {
margin: 0 5px;
}
Expand Down
51 changes: 30 additions & 21 deletions blocks/url-decode/url-decode.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ const DEFAULT_LOCALE = 'us';
/* c8 ignore next */
const delay = (milliseconds) => new Promise((resolve) => { setTimeout(resolve, milliseconds); });

export const loadQueryIndex = async (url) => {
export const loadQueryIndex = async (url, callback = null) => {
const queryData = [];
const response = await fetch(url);

Expand All @@ -22,14 +22,15 @@ export const loadQueryIndex = async (url) => {

queryData.push(...data);
const remaining = total - offset - limit;
callback?.(total - remaining, total);

/* c8 ignore next 7 */
if (remaining > 0) {
const nextUrl = new URL(url);
nextUrl.searchParams.set('limit', limit);
nextUrl.searchParams.set('offset', offset + limit);
await delay(500);
queryData.push(...await loadQueryIndex(nextUrl.toString()));
queryData.push(...await loadQueryIndex(nextUrl.toString(), callback));
}

return queryData;
Expand Down Expand Up @@ -100,7 +101,7 @@ async function decodeUrls(data) {
return decodedLinks;
}

async function validateDecodedUrls(data, configColumn) {
async function validateUrls(data, configColumn) {
return Promise.all(data.map(async (page) => {
const pageUrl = new URL(page.path, window.location.origin);
if (!window.location.pathname.includes('.html')) {
Expand All @@ -111,15 +112,15 @@ async function validateDecodedUrls(data, configColumn) {
const configs = await decodeUrls(page[configColumn]);
const count = configs.length;

if (configs.length === 0) return { path, validation: 'No Config Found', count };
if (configs.length === 0) return { path, valid: true, message: 'No links Found', count };

for (const [i, config] of configs.entries()) {
if (!config) return { path, validation: `Could not decode link ${i + 1}`, count };
if (!config) return { path, valid: false, message: `Could not decode link ${i + 1}`, count };

if (Object.keys(config).length === 0) return { path, validation: 'Empty Config', count };
if (Object.keys(config).length === 0) return { path, valid: false, message: 'Empty link', count };
}

return { path, validation: 'Valid', count };
return { path, valid: true, message: 'Valid link(s) found', count };
}));
}

Expand All @@ -128,31 +129,41 @@ async function generateReport(el, configColumn) {
const locale = el.querySelector('select#locale').value;
const queryIndex = new URL(`${locale}/query-index.json`, window.location.origin);

const indexLink = createTag('p', null, [
'Fetching data from ',
createTag('a', { href: queryIndex.href, target: '_blank' }, queryIndex.href),
]);
report.replaceChildren(indexLink);
const queryLink = createTag('a', { href: queryIndex.href, target: '_blank' }, queryIndex.href);
report.replaceChildren(createTag('p', null, ['Fetching data from ', queryLink]));

let data = [];

try {
data = await loadQueryIndex(queryIndex.href);
data = await loadQueryIndex(queryIndex.href, (offset, total) => {
report.replaceChildren(createTag('p', null, ['Fetching data from ', queryLink, ` (${offset} of ${total})`]));
});
} catch (e) {
/* c8 ignore next 4 */
window.lana?.log(`Error fetching data from url: ${queryIndex.href}`, { tags: 'info,url-decode' });
report.append(createTag('p', { class: 'error' }, 'Error fetching data'));
return;
}

const decodedReports = await validateDecodedUrls(data, configColumn);
const isColumnMissing = !Object.keys(data[0]).includes(configColumn);
const decodedReports = await validateUrls(data, configColumn);
const results = decodedReports.reduce((acc, { valid, count }) => {
acc.count += count;
if (valid) {
acc.valid += 1;
} else {
acc.invalid += 1;
}
return acc;
}, { valid: 0, invalid: 0, count: 0 });

const table = createTable(decodedReports);

const summary = createTag('p', null, `Total: ${data.length}`);
const summary = createTag('p', null, `Valid Pages: ${results.valid}, Invalid Pages: ${results.invalid}, Total Link Count: ${results.count}`);
const error = createTag('p', { class: 'error' }, isColumnMissing ? 'Error: Update query index to include the "caas-url" column.' : '');
const downloadData = encodeURIComponent(data.map((row) => Object.values(row).join(',')).join('\n'));
const download = createTag('a', { href: `data:text/csv;charset=utf-8,${downloadData}`, download: 'data.csv' }, 'Download CSV');
const ribbon = createTag('div', { class: 'ribbon' }, [summary, download]);
const ribbon = createTag('div', { class: 'ribbon' }, [summary, error, download]);

report.append(ribbon, table);
}
Expand All @@ -161,13 +172,11 @@ function onSubmit(el) {
return () => {
const url = new URL(window.location.href);
const title = document.title.split(' - ')[0];
const locale = el.querySelector('select#locale').value;

const selectedLocale = el.querySelector('select#locale').value;

url.searchParams.set('locale', selectedLocale || DEFAULT_LOCALE);
document.title = `${title} - ${selectedLocale || DEFAULT_LOCALE}`;
url.searchParams.set('locale', locale || DEFAULT_LOCALE);
document.title = `${title} - ${locale || DEFAULT_LOCALE}`;
window.history.pushState({}, '', url);

generateReport(el, URL_COLUMN);
};
}
Expand Down
31 changes: 16 additions & 15 deletions test/blocks/url-decode/url-decode.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -98,20 +98,21 @@ describe('URL Decode', () => {

expect(rows).to.have.length(QUERY_INEDX_LENGTH + 1);
expect(rows[0].querySelector('th').textContent).to.equal('path');
expect(rows[0].querySelector('th:nth-child(2)').textContent).to.equal('validation');
expect(rows[0].querySelector('th:nth-child(3)').textContent).to.equal('count');

expect(getCell(rows[1], 2)).to.equal('Valid');
expect(getCell(rows[1], 3)).to.equal('1');
expect(getCell(rows[2], 2)).to.equal('Could not decode link 1');
expect(getCell(rows[2], 3)).to.equal('1');
expect(getCell(rows[3], 2)).to.equal('Valid');
expect(getCell(rows[3], 3)).to.equal('1');
expect(getCell(rows[4], 2)).to.equal('No Config Found');
expect(getCell(rows[4], 3)).to.equal('0');
expect(getCell(rows[5], 2)).to.equal('No Config Found');
expect(getCell(rows[5], 3)).to.equal('0');
expect(getCell(rows[6], 2)).to.equal('No Config Found');
expect(getCell(rows[6], 3)).to.equal('0');
expect(rows[0].querySelector('th:nth-child(2)').textContent).to.equal('valid');
expect(rows[0].querySelector('th:nth-child(3)').textContent).to.equal('message');
expect(rows[0].querySelector('th:nth-child(4)').textContent).to.equal('count');

expect(getCell(rows[1], 3)).to.equal('Valid link(s) found');
expect(getCell(rows[1], 4)).to.equal('1');
expect(getCell(rows[2], 3)).to.equal('Could not decode link 1');
expect(getCell(rows[2], 4)).to.equal('1');
expect(getCell(rows[3], 3)).to.equal('Valid link(s) found');
expect(getCell(rows[3], 4)).to.equal('1');
expect(getCell(rows[4], 3)).to.equal('No links Found');
expect(getCell(rows[4], 4)).to.equal('0');
expect(getCell(rows[5], 3)).to.equal('No links Found');
expect(getCell(rows[5], 4)).to.equal('0');
expect(getCell(rows[6], 3)).to.equal('No links Found');
expect(getCell(rows[6], 4)).to.equal('0');
});
});

0 comments on commit 82cdb85

Please sign in to comment.