Skip to content

Commit

Permalink
Merge pull request #333 from byu-oit/patch/deps
Browse files Browse the repository at this point in the history
v0.4.0
  • Loading branch information
stuft2 committed Apr 5, 2023
2 parents 0597747 + 3f1b5f1 commit d2f92f8
Show file tree
Hide file tree
Showing 8 changed files with 107 additions and 96 deletions.
8 changes: 4 additions & 4 deletions .github/dependabot.yml
Original file line number Diff line number Diff line change
Expand Up @@ -5,18 +5,18 @@ updates:
- package-ecosystem: "npm"
directory: "/"
schedule:
interval: "daily"
interval: "monthly"
target-branch: "main"
# Requesting reviews from yourself makes Dependabot PRs easy to find (https://github.com/pulls/review-requested)
reviewers:
- "yoshutch"
- "@byu-oit/specops-developer-fte"

# GitHub Actions
- package-ecosystem: "github-actions"
directory: "/" # For GitHub Actions, set the directory to / to check for workflow files in .github/workflows. (GitHub Docs)
schedule:
interval: "daily"
interval: "monthly"
target-branch: "main"
# Requesting reviews from yourself makes Dependabot PRs easy to find (https://github.com/pulls/review-requested)
reviewers:
- "yoshutch"
- "@byu-oit/specops-developer-fte"
16 changes: 8 additions & 8 deletions .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -12,21 +12,21 @@ on:
- .github/workflows/bump.yml

env:
node_version: "16.x"
node_version: "18.x"

jobs:
test:
name: Test Module
runs-on: ubuntu-latest
strategy:
matrix:
node-version: [12.x, 14.x, 16.x]
node-version: [16.x, 18.x]
fail-fast: false
steps:
- uses: actions/checkout@v2
- uses: actions/checkout@v3

- name: Set up Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v2
uses: actions/setup-node@v3
with:
node-version: ${{ matrix.node-version }}

Expand All @@ -42,7 +42,7 @@ jobs:

- name: Upload coverage to Codecov
if: ${{ matrix.node-version == env.node_version }} # just run coverage if node 16
uses: codecov/codecov-action@v2
uses: codecov/codecov-action@v3
with:
token: ${{ secrets.CODECOV_TOKEN }}
fail_ci_if_error: true
Expand All @@ -51,10 +51,10 @@ jobs:
name: Lint Module
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- uses: actions/checkout@v3

- name: Set up Node.js
uses: actions/setup-node@v2
uses: actions/setup-node@v3
with:
node-version: ${{ env.node_version }}

Expand All @@ -70,7 +70,7 @@ jobs:
runs-on: ubuntu-latest
needs: [test, lint]
steps:
- uses: actions/checkout@v2
- uses: actions/checkout@v3

- id: version
run: echo ::set-output name=version::$(node -p 'require("./package.json").version')
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/deploy.yml
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ on:
- .github/workflows/bump.yml

env:
node_version: "16.x"
node_version: "18.x"

jobs:
env:
Expand Down
2 changes: 1 addition & 1 deletion LICENSE
Original file line number Diff line number Diff line change
Expand Up @@ -186,7 +186,7 @@
same "printed page" as the copyright notice for easier
identification within third-party archives.

Copyright 2021 Brigham Young University
Copyright 2023 Brigham Young University

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
Expand Down
40 changes: 23 additions & 17 deletions package.json
Original file line number Diff line number Diff line change
@@ -1,45 +1,51 @@
{
"name": "@byu-oit/logger",
"version": "0.3.14",
"version": "0.4.0",
"description": "Default configuration for pino logger",
"contributors": [
"Scott Hutchings <scott_hutchings@byu.edu>"
{
"name": "Scott Hutching",
"email": "scott_hutchings@byu.edu"
},
{
"name": "Spencer Tuft",
"email": "stuft2@byu.edu"
}
],
"main": "dist/logger.js",
"types": "dist/logger.d.ts",
"files": [
"dist/**/*"
"dist"
],
"scripts": {
"build": "rimraf dist && tsc",
"build": "npx rimraf dist && tsc",
"coverage": "npm run test -- --coverage || exit 0",
"lint": "ts-standard | snazzy",
"lint:fix": "ts-standard --fix | snazzy",
"lint": "npx ts-standard | snazzy",
"lint:fix": "npx ts-standard --fix | snazzy",
"test": "jest",
"prepublishOnly": "npm run build"
},
"author": "Brigham Young University - Office of Information Technology",
"license": "Apache-2.0",
"dependencies": {
"deepmerge": "^4.2.2",
"pino": "^6.13.3"
"pino": "^8.11.0",
"pino-http": "^6.6.0"
},
"devDependencies": {
"@tsconfig/node12": "^1.0.9",
"@types/jest": "^27.0.1",
"@tsconfig/node12": "^1.0.11",
"@types/jest": "^29.5.0",
"@types/node": "^16.9.1",
"@types/pino": "^6.3.12",
"jest": "^27.2.0",
"@types/pino": "^7.0.5",
"jest": "^29.5.0",
"lint-staged": "^12.0.2",
"pino-pretty": "^6.0.0",
"rimraf": "^3.0.2",
"pino-pretty": "^10.0.0",
"snazzy": "^9.0.0",
"ts-jest": "^27.0.5",
"ts-standard": "^11.0.0",
"typescript": "^4.4.3"
"ts-jest": "^29.1.0",
"typescript": "^5.0.3"
},
"optionalDependencies": {
"pino-pretty": "<6"
"pino-pretty": ">=7"
},
"engines": {
"node": ">=12"
Expand Down
24 changes: 14 additions & 10 deletions src/logger.ts
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
import Pino from 'pino'
import { getLevel, isInstalled } from './util'
import { Logger, LoggerOptions, pino } from 'pino'
import { getLevel, isInstalled, isProduction } from './util'
import deepmerge from 'deepmerge'

export default function DefaultLogger (options?: Pino.LoggerOptions): Pino.Logger {
const defaultOptions: Pino.LoggerOptions = {
export function ByuLogger (options?: LoggerOptions): Logger {
const defaultOptions: LoggerOptions = {
level: getLevel(process.env.NODE_ENV),
messageKey: 'message',
formatters: {
Expand All @@ -15,12 +15,16 @@ export default function DefaultLogger (options?: Pino.LoggerOptions): Pino.Logge
paths: ['req.headers.authorization', 'req.headers.assertion', 'req.headers["x-jwt-assertion"]', 'req.headers["x-jwt-assertion-original"]'],
censor: '***'
},
// if in local environment use pretty print logs
...process.env.NODE_ENV !== 'production' && isInstalled('pino-pretty') && {
prettyPrint: { translateTime: 'UTC:yyyy-mm-dd\'T\'HH:MM:ss.l\'Z\'' } // show timestamp instead of epoch time
// if in local environment try to pretty print logs
...!isProduction() && isInstalled('pino-pretty') && {
transport: {
target: 'pino-pretty',
options: { translateTime: 'UTC:yyyy-mm-dd\'T\'HH:MM:ss.l\'Z\'' }
}
}
}

const opts: Pino.LoggerOptions = options == null ? defaultOptions : deepmerge(defaultOptions, options)
return Pino(opts)
const opts: LoggerOptions = options == null ? defaultOptions : deepmerge(defaultOptions, options)
return pino(opts)
}

export default ByuLogger
6 changes: 5 additions & 1 deletion src/util.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,10 @@ export function getLevel (level: string = 'default'): Pino.LevelWithSilent {
return ENV_LEVELS[level] ?? ENV_LEVELS.default
}

export function isProduction (): boolean {
return process.env.NODE_ENV === 'production'
}

export function isInstalled (name: string): boolean {
try {
return require(name) != null
Expand All @@ -26,5 +30,5 @@ export function isRecord (value: unknown): value is Record<string, unknown> {
}

export function hasProperty<T = unknown> (value: T, prop: string | number | symbol): prop is keyof T {
return prop in value
return Object.hasOwnProperty.call(value, prop)
}
105 changes: 51 additions & 54 deletions test/logger.spec.ts
Original file line number Diff line number Diff line change
@@ -1,9 +1,11 @@
import DefaultLogger from '../src/logger'
import { ByuLogger } from '../src/logger'
import { Logger } from 'pino'

const jan1st = new Date(2021, 0, 1)
const dateNowStub = jest.fn(() => jan1st.getTime())
const realDateNow = Date.now.bind(global.Date)
let logged: string = ''
let logger: Logger

beforeAll(() => {
process.stdout.write = (buffer: string) => {
Expand All @@ -21,69 +23,67 @@ afterEach(() => {
global.Date.now = realDateNow
})

describe('In local env', () => {
beforeEach(() => {
process.env.NODE_ENV = 'local'
})

test('default logger should default to debug level', () => {
const logger = DefaultLogger()
logger.debug('debug works')

expect(logger.level).toEqual('debug')
expect(logged).toContain('DEBUG') // must contain the debug level
expect(logged).toContain('debug works') // must contain the message
})

test('default logger should still display info', () => {
const logger = DefaultLogger()
logger.info('info works')

expect(logged).toContain('INFO') // must contain the info level
expect(logged).toContain('info works') // must contain the message
})

test('default logger displays logs with iso datetime format', () => {
const logger = DefaultLogger()
logger.info('iso date works')

expect(logged).toContain(`[${jan1st.toISOString()}]`)
})

test('default logger displays logs in pretty printed format', () => {
const logger = DefaultLogger()
logger.info('pretty print works')

expect(logged).not.toContain('{')
})

// TODO - Figure out how to stub `require` to throw a fake MODULE_NOT_FOUND error
// test('default logger does not pretty print if pino-pretty is not installed', async () => {
// proxyquire('../src/logger', {
// 'pino-pretty': null
// })
//
// const logger = DefaultLogger()
// logger.info('pretty print disabled')
// expect(logged).toContain('{')
// })
})
// Pino v7+ implements transports which are problematic in Jest environments.
// Docs: https://github.com/pinojs/pino-pretty#usage-with-jest
// describe('In local env', () => {
// beforeEach(() => {
// process.env.NODE_ENV = 'local'
// logger = ByuLogger()
// })
//
// test('default logger should default to debug level', () => {
// logger.debug('debug works')
//
// expect(logger.level).toEqual('debug')
// expect(logged).toContain('DEBUG') // must contain the debug level
// expect(logged).toContain('debug works') // must contain the message
// })
//
// test('default logger should still display info', () => {
// logger.info('info works')
//
// expect(logged).toContain('INFO') // must contain the info level
// expect(logged).toContain('info works') // must contain the message
// })
//
// test('default logger displays logs with iso datetime format', () => {
// logger.info('iso date works')
//
// expect(logged).toContain(`[${jan1st.toISOString()}]`)
// })
//
// test('default logger displays logs in pretty printed format', () => {
// logger.info('pretty print works')
//
// expect(logged).not.toContain('{')
// })
//
// // TODO - Figure out how to stub `require` to throw a fake MODULE_NOT_FOUND error
// // test('default logger does not pretty print if pino-pretty is not installed', async () => {
// // proxyquire('../src/logger', {
// // 'pino-pretty': null
// // })
// //
// // const logger = ByuLogger()
// // logger.info('pretty print disabled')
// // expect(logged).toContain('{')
// // })
// })

describe('In production env', () => {
beforeEach(() => {
process.env.NODE_ENV = 'production'
logger = ByuLogger()
})

test('default logger should default to info level', () => {
const logger = DefaultLogger()
logger.debug('debug does not work')

expect(logger.level).toEqual('info')
expect(logged).toEqual('') // no logs should have happened
})

test('default logger displays logs in JSON format', () => {
const logger = DefaultLogger()
logger.info('json works')

expect(logged).toContain('{')
Expand All @@ -94,7 +94,6 @@ describe('In production env', () => {
})

test('default logger should display info logs', () => {
const logger = DefaultLogger()
logger.info('info works')

const jsonLogEntry = JSON.parse(logged)
Expand All @@ -103,7 +102,6 @@ describe('In production env', () => {
})

test('default logger displays logs with epoch datetime format', () => {
const logger = DefaultLogger()
logger.info('iso date works')

const jsonLogEntry = JSON.parse(logged)
Expand All @@ -114,18 +112,17 @@ describe('In production env', () => {
describe('In test env', () => {
beforeEach(() => {
process.env.NODE_ENV = 'test'
logger = ByuLogger()
})

test('default logger should default to silent level', () => {
const logger = DefaultLogger()
logger.debug('debug does not work')

expect(logger.level).toEqual('silent')
expect(logged).toEqual('') // no logs should have happened
})

test('default logger should not display logs', () => {
const logger = DefaultLogger()
logger.info('info works')

expect(logged).toEqual('')
Expand Down

0 comments on commit d2f92f8

Please sign in to comment.