Skip to content

Commit

Permalink
feat: adding list of project (#233)
Browse files Browse the repository at this point in the history
feat: adding list of project
  • Loading branch information
kodiakhq[bot] authored May 19, 2022
2 parents c989a2b + 5de7a43 commit 161d031
Show file tree
Hide file tree
Showing 16 changed files with 625 additions and 11 deletions.
File renamed without changes.
File renamed without changes.
10 changes: 10 additions & 0 deletions __mocks__/contents/project/test-project.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
---
title: Project Title
status: Under Development
description: project description
programming_languange: ['typescript']
cover: data-penyimpanan_xdqfzd.webp
isPublished: true
---

project content
10 changes: 3 additions & 7 deletions __tests__/pages/Blog/index.test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -46,15 +46,15 @@ useRouter.mockImplementation(() => ({
}))

const renderBlogSlug = async () => {
const post = new BlogContext('contents/blog')
const post = new BlogContext('__mocks__/contents/blog')
const posts = await post.getAllPublishArticle()

const utils = render(<Blog posts={posts} tags={['Testing 101']} />)

return { utils }
}

describe('Blog', () => {
describe('Blog Pages', () => {
it('Show Title Page', async () => {
const { utils } = await renderBlogSlug()

Expand All @@ -74,11 +74,7 @@ describe('Blog', () => {

expect(result).toMatchInlineSnapshot(`
Array [
"Struktur Data Heap",
"Parsing Data Standard Input Pada Go",
"Self Reflection 2021",
"Algoritma Binary Search",
"Fundamental Algoritma",
"Testing 101",
]
`)
})
Expand Down
6 changes: 3 additions & 3 deletions __tests__/pages/Blog/slug.test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -67,8 +67,8 @@ useRouter.mockImplementation(() => ({
}))

const renderBlogSlug = async () => {
const post = new BlogContext('contents/blog')
const posts = await post.getArticleWithMetadata('id-fundamental-algoritma')
const post = new BlogContext('__mocks__/contents/blog')
const posts = await post.getArticleWithMetadata('id-test-markdown')

const utils = render(
<Blog posts={posts} blurDataURL={posts.metadata.blurDataURL} />
Expand All @@ -77,7 +77,7 @@ const renderBlogSlug = async () => {
return { utils }
}

describe('Blog', () => {
describe('Blog Content', () => {
it('Show Title Page', async () => {
const { utils } = await renderBlogSlug()

Expand Down
81 changes: 81 additions & 0 deletions __tests__/pages/project/index.test.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,81 @@
/**
* @jest-environment jsdom
*/
import React from 'react'
import { render, within } from '../../../__mocks__/utils/test-providers'
import Project from '../../../src/pages/project/index'
import ProjectContext from '../../../src/context/project/index'
import { library } from '@fortawesome/fontawesome-svg-core'
import {
faGithubSquare,
faTwitterSquare,
faLinkedin,
} from '@fortawesome/free-brands-svg-icons'
import { faBars, faTimes, faRssSquare } from '@fortawesome/free-solid-svg-icons'

library.add(
faGithubSquare,
faTwitterSquare,
faLinkedin,
faTimes,
faBars,
faRssSquare
)

jest.mock('remark-math', () => jest.fn())
jest.mock('rehype-katex', () => jest.fn())
jest.mock('unist-util-visit', () => jest.fn())
jest.mock('hast-util-to-string', () => jest.fn())
jest.mock('refractor', () => jest.fn())
jest.mock('hast-util-to-html', () => jest.fn())
jest.mock('unified', () => jest.fn())
jest.mock('rehype-parse', () => jest.fn())

const useRouter = jest.spyOn(require('next/router'), 'useRouter')
jest.mock('plaiceholder', () => ({
getPlaiceholder: jest.fn(() => {
return {
base64: '',
}
}),
}))

useRouter.mockImplementation(() => ({
route: '/',
pathname: '/',
}))

const renderBlogSlug = async () => {
const project = new ProjectContext('__mocks__/contents/project')
const projects = await project.getAllPublishedProject()

const utils = render(<Project projects={projects} tags={['Testing 101']} />)

return { utils }
}

describe('Project Pages', () => {
it('Show Title Page', async () => {
const { utils } = await renderBlogSlug()

const heading = utils.getByRole('heading', {
name: /Projects/i,
})

expect(heading).toBeInTheDocument()
})

it('This project pages will show the list of article', async () => {
const { utils } = await renderBlogSlug()

const result = utils.getAllByRole('article').map((article) => {
return within(article).getByRole('heading').textContent
})

expect(result).toMatchInlineSnapshot(`
Array [
"Project Title",
]
`)
})
})
92 changes: 92 additions & 0 deletions __tests__/pages/project/slug.test.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,92 @@
/**
* @jest-environment jsdom
*/
import React from 'react'
import { render } from '../../../__mocks__/utils/test-providers'
import Project from '../../../src/pages/project/[slug]'
import ProjectContext from '../../../src/context/project/index'
import { library } from '@fortawesome/fontawesome-svg-core'
import {
faGithubSquare,
faTwitterSquare,
faLinkedin,
} from '@fortawesome/free-brands-svg-icons'
import { faBars, faTimes, faRssSquare } from '@fortawesome/free-solid-svg-icons'

library.add(
faGithubSquare,
faTwitterSquare,
faLinkedin,
faTimes,
faBars,
faRssSquare
)

jest.mock('remark-math', () => jest.fn())
jest.mock('rehype-katex', () => jest.fn())
jest.mock('unist-util-visit', () => jest.fn())
jest.mock('hast-util-to-string', () => jest.fn())
jest.mock('refractor', () => jest.fn())
jest.mock('hast-util-to-html', () => jest.fn())
jest.mock('unified', () => jest.fn())
jest.mock('rehype-parse', () => jest.fn())
jest.mock('mdx-bundler', () => ({
bundleMDX: jest.fn(() => {
return {
code: `var Component=(()=>{var d=Object.create;var c=Object.defineProperty;var m=Object.getOwnPropertyDescriptor;var u=Object.getOwnPropertyNames;var j=Object.getPrototypeOf,l=Object.prototype.hasOwnProperty;var x=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports),_=(t,e)=>{for(var n in e)c(t,n,{get:e[n],enumerable:!0})},i=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of u(e))!l.call(t,o)&&o!==n&&c(t,o,{get:()=>e[o],enumerable:!(r=m(e,o))||r.enumerable});return t};var f=(t,e,n)=>(n=t!=null?d(j(t)):{},i(e||!t||!t.__esModule?c(n,"default",{value:t,enumerable:!0}):n,t)),g=t=>i(c({},"__esModule",{value:!0}),t);var a=x((v,p)=>{p.exports=_jsx_runtime});var D={};_(D,{default:()=>y,frontmatter:()=>b});var s=f(a()),b={title:"Project Title",status:"Under Development",description:"project description",programming_languange:["typescript"],cover:"data-penyimpanan_xdqfzd.webp",isPublished:!0};function h(t={}){let{wrapper:e}=t.components||{};return e?(0,s.jsx)(e,Object.assign({},t,{children:(0,s.jsx)(n,{})})):n();function n(){let r=Object.assign({p:"p"},t.components);return(0,s.jsx)(r.p,{children:"project content"})}}var y=h;return g(D);})();
;return Component;`,
frontmatter: {
title: 'Personal Project',
isPublished: true,
cover: '/content/bias-kognitif.jpg',
description: 'project description',
blurDataURL: '/content/bias-kognitif.jpg,',
status: 'Under Development',
programming_languange: ['typescript'],
},
}
}),
}))

jest.mock('plaiceholder', () => ({
getPlaiceholder: jest.fn(() => {
return {
base64: '',
}
}),
}))

const useRouter = jest.spyOn(require('next/router'), 'useRouter')

useRouter.mockImplementation(() => ({
route: '/',
pathname: '/',
}))

const renderBlogSlug = async () => {
const project = new ProjectContext('__mocks__/contents/project')
const projects = await project.getProjectDetail('test-project')

const utils = render(
<Project
projects={projects}
blurDataURL={projects.metadata.blurDataURL}
/>
)

return { utils }
}

describe('Project Content', () => {
it('Show Project Content', async () => {
const { utils } = await renderBlogSlug()

const heading = utils.getByRole('heading', {
name: /Personal Project/i,
})
const body = utils.getByText('project content')

expect(heading).toBeInTheDocument()
expect(body).toBeInTheDocument()
})
})
25 changes: 25 additions & 0 deletions contents/project/personal-web-app.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
---
title: Personal Web App
status: Under Development
description: project
programming_languange: ['typescript']
cover: data-penyimpanan_xdqfzd.webp
isPublished: false
---

### Goals

- To have brand awareness for personal branding (Job Security)
- To Improve clear communication skill & writting skill

### Objectives

- 100 Articles
- 20 Project

### Tech Stack

- NextJS: Solving configuration project
- Tailwind: Making CSS easy to use because of inlining directly to react component
- React Testing Library: Solving integration testing within react component
- mdx-bundler: Solving markdown parsed into HTML to be rendered
Loading

0 comments on commit 161d031

Please sign in to comment.