Skip to content

Commit

Permalink
Merge pull request #18260 from github/repo-sync
Browse files Browse the repository at this point in the history
repo sync
  • Loading branch information
Octomerger authored May 26, 2022
2 parents 147e14f + 952c76d commit 2b2f752
Show file tree
Hide file tree
Showing 4 changed files with 74 additions and 70 deletions.
48 changes: 48 additions & 0 deletions tests/rendering/products.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
import { describe, jest } from '@jest/globals'

import { getDOM, getJSON } from '../helpers/e2etest.js'
import nonEnterpriseDefaultVersion from '../../lib/non-enterprise-default-version.js'

describe('mobile-only products nav', () => {
const cases = [
// Note the unversioned homepage at `/` does not have a product selected in the mobile dropdown
['/github', 'GitHub'],
// Enterprise server
['/en/enterprise/admin', 'Enterprise administrators'],
[
'/en/enterprise/get-started/importing-your-projects-to-github/importing-source-code-to-github/importing-a-git-repository-using-the-command-line',
'Get started',
],

['/desktop', 'GitHub Desktop'],
['/actions', 'GitHub Actions'],

// localized
['/ja/desktop', 'GitHub Desktop'],
]

test.each(cases)('on %p, renders current product %p', async (url, name) => {
expect((await getDOM(url))('[data-testid=product-picker] summary').text().trim()).toBe(name)
})
})

describe('products middleware', () => {
jest.setTimeout(5 * 60 * 1000)

test('adds res.context.activeProducts array', async () => {
const products = await getJSON('/en?json=activeProducts')
expect(Array.isArray(products)).toBe(true)
})

test('adds res.context.currentProduct string on homepage', async () => {
const currentProduct = await getJSON('/en?json=currentProduct')
expect(currentProduct).toBe('homepage')
})

test('adds res.context.currentProduct object', async () => {
const currentProduct = await getJSON(
`/en/${nonEnterpriseDefaultVersion}/github?json=currentProduct`
)
expect(currentProduct).toBe('github')
})
})
26 changes: 26 additions & 0 deletions tests/rendering/versions.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
import { describe, jest } from '@jest/globals'

import { allVersions } from '../../lib/all-versions.js'
import { latest } from '../../lib/enterprise-server-releases.js'
import nonEnterpriseDefaultVersion from '../../lib/non-enterprise-default-version.js'
import { getJSON } from '../helpers/e2etest.js'

describe('versions middleware', () => {
jest.setTimeout(60 * 1000)

test('adds res.context.allVersions object', async () => {
const allVersionsFromMiddleware = await getJSON('/en?json=allVersions')
expect(allVersionsFromMiddleware).toEqual(allVersions)
})

test('adds res.context.currentVersion string', async () => {
let currentVersion = await getJSON('/en?json=currentVersion')
expect(currentVersion).toBe(nonEnterpriseDefaultVersion)

currentVersion = await getJSON(`/en/${nonEnterpriseDefaultVersion}?json=currentVersion`)
expect(currentVersion).toBe(nonEnterpriseDefaultVersion)

currentVersion = await getJSON(`/en/enterprise-server@${latest}?json=currentVersion`)
expect(currentVersion).toBe(`enterprise-server@${latest}`)
})
})
49 changes: 0 additions & 49 deletions tests/unit/products.js
Original file line number Diff line number Diff line change
@@ -1,11 +1,6 @@
import { jest } from '@jest/globals'
import revalidator from 'revalidator'
import { productMap } from '../../lib/all-products.js'
import schema from '../helpers/schemas/products-schema.js'
import { getDOM, getJSON } from '../helpers/supertest.js'
import nonEnterpriseDefaultVersion from '../../lib/non-enterprise-default-version.js'

jest.useFakeTimers('legacy')

describe('products module', () => {
test('is an object with product ids as keys', () => {
Expand All @@ -21,47 +16,3 @@ describe('products module', () => {
})
})
})

describe('mobile-only products nav', () => {
const cases = [
// Note the unversioned homepage at `/` does not have a product selected in the mobile dropdown
['/github', 'GitHub'],
// Enterprise server
['/en/enterprise/admin', 'Enterprise administrators'],
[
'/en/enterprise/get-started/importing-your-projects-to-github/importing-source-code-to-github/importing-a-git-repository-using-the-command-line',
'Get started',
],

['/desktop', 'GitHub Desktop'],
['/actions', 'GitHub Actions'],

// localized
['/ja/desktop', 'GitHub Desktop'],
]

test.each(cases)('on %p, renders current product %p', async (url, name) => {
expect((await getDOM(url))('[data-testid=product-picker] summary').text().trim()).toBe(name)
})
})

describe('products middleware', () => {
jest.setTimeout(5 * 60 * 1000)

test('adds res.context.activeProducts array', async () => {
const products = await getJSON('/en?json=activeProducts')
expect(Array.isArray(products)).toBe(true)
})

test('adds res.context.currentProduct string on homepage', async () => {
const currentProduct = await getJSON('/en?json=currentProduct')
expect(currentProduct).toBe('homepage')
})

test('adds res.context.currentProduct object', async () => {
const currentProduct = await getJSON(
`/en/${nonEnterpriseDefaultVersion}/github?json=currentProduct`
)
expect(currentProduct).toBe('github')
})
})
21 changes: 0 additions & 21 deletions tests/unit/versions.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@ import revalidator from 'revalidator'
import { allVersions } from '../../lib/all-versions.js'
import { latest } from '../../lib/enterprise-server-releases.js'
import schema from '../helpers/schemas/versions-schema.js'
import { getJSON } from '../helpers/supertest.js'
import nonEnterpriseDefaultVersion from '../../lib/non-enterprise-default-version.js'

jest.useFakeTimers('legacy')
Expand All @@ -22,23 +21,3 @@ describe('versions module', () => {
})
})
})

describe('versions middleware', () => {
jest.setTimeout(5 * 60 * 1000)

test('adds res.context.allVersions object', async () => {
const allVersionsFromMiddleware = await getJSON('/en?json=allVersions')
expect(allVersionsFromMiddleware).toEqual(allVersions)
})

test('adds res.context.currentVersion string', async () => {
let currentVersion = await getJSON('/en?json=currentVersion')
expect(currentVersion).toBe(nonEnterpriseDefaultVersion)

currentVersion = await getJSON(`/en/${nonEnterpriseDefaultVersion}?json=currentVersion`)
expect(currentVersion).toBe(nonEnterpriseDefaultVersion)

currentVersion = await getJSON(`/en/enterprise-server@${latest}?json=currentVersion`)
expect(currentVersion).toBe(`enterprise-server@${latest}`)
})
})

0 comments on commit 2b2f752

Please sign in to comment.