From 8e7726a5c394d472521240e1cd4b6c18f83688ef Mon Sep 17 00:00:00 2001 From: Muhammad Afaq Shuaib <78806673+AfaqShuaib09@users.noreply.github.com> Date: Fri, 8 Sep 2023 12:42:45 +0500 Subject: [PATCH] chore: add subdirectory slug format for bootcamps (#910) --- src/data/constants/index.js | 2 ++ src/setupTest.js | 8 ++++++++ src/utils/utils.test.js | 23 ++++++++++++++++++++++- 3 files changed, 32 insertions(+), 1 deletion(-) diff --git a/src/data/constants/index.js b/src/data/constants/index.js index f95955087..68d0691da 100644 --- a/src/data/constants/index.js +++ b/src/data/constants/index.js @@ -21,6 +21,7 @@ const FORMAT_DATE_MATCHER = /20\d{2}-(0\d{1}|1[0-2])-([0-2]\d{1}|3[0-1])/; const NORMALIZE_DATE_MATCHER = /20\d{2}\/(0\d{1}|1[0-2])\/([0-2]\d{1}|3[0-1])/; const EXECUTIVE_EDUCATION_SLUG = 'executive-education-2u'; +const BOOTCAMP_SLUG = 'bootcamp-2u'; const COURSE_URL_SLUG_PATTERN_OLD = '^[a-z0-9_]+(?:-[a-z0-9_]+)*$'; const COURSE_URL_SLUG_PATTERN_NEW = '^learn/[a-z0-9_]+(?:-?[a-z0-9_]+)*/[a-z0-9_]+(?:-?[a-z0-9_]+)*$'; @@ -53,6 +54,7 @@ export { COURSE_EXEMPT_FIELDS, COURSE_RUN_NON_EXEMPT_FIELDS, EXECUTIVE_EDUCATION_SLUG, + BOOTCAMP_SLUG, COURSE_URL_SLUG_PATTERN, COURSE_URL_SLUG_PATTERN_NEW, COURSE_URL_SLUG_PATTERN_OLD, diff --git a/src/setupTest.js b/src/setupTest.js index d3c30e191..16ef17044 100644 --- a/src/setupTest.js +++ b/src/setupTest.js @@ -17,6 +17,10 @@ process.env.COURSE_URL_SLUGS_PATTERN = `{ "default": { "slug_format": "^learn/[a-z0-9_]+(?:-?[a-z0-9_]+)*/[a-z0-9_]+(?:-?[a-z0-9_]+)*$|^[a-z0-9_]+(?:-[a-z0-9_]+)*$", "error_msg": "Course URL slug contains lowercase letters, numbers, underscores, and dashes only and must be in the format or learn//-." + }, + "bootcamp-2u": { + "slug_format": "^boot-camps/[a-z0-9_]+(?:-?[a-z0-9_]+)*/[a-z0-9_]+(?:-?[a-z0-9_]+)*$|^[a-z0-9_]+(?:-[a-z0-9_]+)*$", + "error_msg": "Course URL slug contains lowercase letters, numbers, underscores, and dashes only and must be in the format or boot-camps//-." } }, "external-source": { @@ -27,6 +31,10 @@ process.env.COURSE_URL_SLUGS_PATTERN = `{ "executive-education-2u": { "slug_format": "^executive-education/[a-z0-9_]+(?:-?[a-z0-9_]+)*$|^[a-z0-9_]+(?:-[a-z0-9_]+)*$", "error_msg": "Course URL slug contains lowercase letters, numbers, underscores, and dashes only and must be in the format or executive-education/-." + }, + "bootcamp-2u": { + "slug_format": "^boot-camps/[a-z0-9_]+(?:-?[a-z0-9_]+)*/[a-z0-9_]+(?:-?[a-z0-9_]+)*$|^[a-z0-9_]+(?:-[a-z0-9_]+)*$", + "error_msg": "Course URL slug contains lowercase letters, numbers, underscores, and dashes only and must be in the format or boot-camps//-." } } }`; diff --git a/src/utils/utils.test.js b/src/utils/utils.test.js index f06d46b4a..aec9d3173 100644 --- a/src/utils/utils.test.js +++ b/src/utils/utils.test.js @@ -1,5 +1,5 @@ import * as utils from '.'; -import { COURSE_URL_SLUG_PATTERN_OLD, EXECUTIVE_EDUCATION_SLUG } from '../data/constants'; +import { BOOTCAMP_SLUG, COURSE_URL_SLUG_PATTERN_OLD, EXECUTIVE_EDUCATION_SLUG } from '../data/constants'; import { DEFAULT_PRODUCT_SOURCE } from '../data/constants/productSourceOptions'; const initialRuns = [ @@ -129,6 +129,27 @@ describe('getCourseUrlSlugPattern', () => { }); }, ); + + it( + 'returns the old course url slug pattern when courseType is bootcamp and updatedSlugFlag is false', + () => { + expect( + utils.getCourseUrlSlugPattern(false, 'external-source', BOOTCAMP_SLUG), + ).toEqual({ + slug_format: COURSE_URL_SLUG_PATTERN_OLD, + error_msg: 'Course URL slug contains lowercase letters, numbers, underscores, and dashes only.', + }); + }, + ); + + it( + 'returns the bootcamp subdirectory slug pattern when courseType is bootcamp and updatedSlugFlag is true', + () => { + expect( + utils.getCourseUrlSlugPattern(true, 'external-source', BOOTCAMP_SLUG), + ).toEqual(JSON.parse(COURSE_URL_SLUGS_PATTERN)['external-source'][BOOTCAMP_SLUG]); + }, + ); }); describe('getCourseError', () => {