Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

ci: #174 Prettier setup #169

Merged
merged 45 commits into from
May 1, 2024
Merged
Show file tree
Hide file tree
Changes from 42 commits
Commits
Show all changes
45 commits
Select commit Hold shift + click to select a range
1b86912
removed tslint
miquelbeltran Apr 24, 2024
2594236
add eslint
miquelbeltran Apr 24, 2024
0a8f09d
add default config
miquelbeltran Apr 24, 2024
e05676e
setup default config and npm run command
miquelbeltran Apr 24, 2024
efb470f
add command to node.js.yml
miquelbeltran Apr 24, 2024
930758a
set rules to support current codebase
miquelbeltran Apr 24, 2024
7c144e1
remove unused tslint.json
miquelbeltran Apr 24, 2024
81e4cae
include sample files in eslint command
miquelbeltran Apr 24, 2024
c7bdcc7
remove rule no-explicit-any
miquelbeltran Apr 25, 2024
abdd156
specify type for timer
miquelbeltran Apr 25, 2024
44adb8f
remove any from filterKeys
miquelbeltran Apr 25, 2024
284f95b
explictly declare that error can be Error, String but still accept an…
miquelbeltran Apr 25, 2024
28c3bbf
specify types in the sync worker
miquelbeltran Apr 25, 2024
a0df356
improve the IndexableError type
miquelbeltran Apr 25, 2024
57cffc7
explain why any is allowed in CustomData
miquelbeltran Apr 25, 2024
4bcc97b
remove no-this-alias from eslint config
miquelbeltran Apr 25, 2024
6dc0bc0
convert to arrow function to preserve this reference
miquelbeltran Apr 25, 2024
aa0f0a7
use arrow functions to remove the need of a this alias
miquelbeltran Apr 25, 2024
8eb988d
define httpoptions object instead of using this alias
miquelbeltran Apr 25, 2024
bd80137
add examples to prettier command
miquelbeltran Apr 26, 2024
f541a58
add prettier job to node js ci job
miquelbeltran Apr 26, 2024
afb6966
script fix
miquelbeltran Apr 26, 2024
33401d1
setup no-unused-vars lint rule
miquelbeltran Apr 26, 2024
6471ea9
remove unused var
miquelbeltran Apr 26, 2024
0ed84f2
fixed lib/raygun.batch.ts
miquelbeltran Apr 26, 2024
4be2baf
fix lib/raygun.offline.ts
miquelbeltran Apr 26, 2024
04e8ecc
cleanup lib/raygun.sync.transport.ts
miquelbeltran Apr 26, 2024
1a4387d
fix lib/raygun.transport.ts
miquelbeltran Apr 26, 2024
dce77e5
fix lib/raygun.ts
miquelbeltran Apr 26, 2024
0193863
fix @typescript-eslint/no-unused-vars
miquelbeltran Apr 26, 2024
4ec2f88
fixs in test files
miquelbeltran Apr 26, 2024
68c932b
Merge branch 'develop' into 158-eslint-fixes
miquelbeltran Apr 29, 2024
5ad42ce
update package lock in sample
miquelbeltran Apr 29, 2024
5eda8d9
Merge branch '158-eslint-fixes' into 158-no-this-alias
miquelbeltran Apr 29, 2024
ffc573f
Merge branch '158-no-this-alias' into 158-no-unused-vars
miquelbeltran Apr 29, 2024
14a8fbb
cleanup eslint config
miquelbeltran Apr 29, 2024
5d1a95f
Merge branch '158-no-unused-vars' into prettier-setup
miquelbeltran Apr 29, 2024
9c1f1f0
config files
miquelbeltran Apr 29, 2024
40308df
run npm run prettier
miquelbeltran Apr 29, 2024
c97e053
Update .github/workflows/node.js.yml
miquelbeltran Apr 30, 2024
5c7ad48
fix workflow
miquelbeltran Apr 30, 2024
3b4325e
add comments to the package.json
miquelbeltran Apr 30, 2024
94a4cfc
Merge branch 'develop' into prettier-setup
miquelbeltran May 1, 2024
ce51d28
add missing files
miquelbeltran May 1, 2024
cb7797b
remove fetch-depth: 0
miquelbeltran May 1, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
26 changes: 26 additions & 0 deletions .github/workflows/node.js.yml
Original file line number Diff line number Diff line change
Expand Up @@ -29,3 +29,29 @@ jobs:
- run: npm ci
- run: npm test
- run: npm run eslint

# Checks code formatting, fails if there are changes after applying prettier.
# Based on this example here:
# https://github.com/creyD/prettier_action?tab=readme-ov-file#example-4-dry-run
prettier:
runs-on: ubuntu-latest

steps:
- name: Checkout
uses: actions/checkout@v3
sumitramanga marked this conversation as resolved.
Show resolved Hide resolved
with:
# Make sure the actual branch is checked out when running on pull requests
ref: ${{ github.head_ref }}
# This is important to fetch the changes to the previous commit
fetch-depth: 0
# Make sure the value of GITHUB_TOKEN will not be persisted in repo's config
persist-credentials: false

- name: Prettify code
uses: creyD/[email protected]
with:
# "dry" causes that if any file is modified, the job fails
dry: True
# "write" performs changes in place
prettier_options: --write lib/*.ts test/*.js examples/**/*.js
github_token: ${{ secrets.PERSONAL_GITHUB_TOKEN }}
11 changes: 8 additions & 3 deletions eslint.config.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -8,10 +8,15 @@ export default tseslint.config(
...tseslint.configs.recommended,
{
rules: {
// Unused vars reported as error
"@typescript-eslint/no-unused-vars": [
"error",
{
// Do not report unused function arguments
"args": "none",
}
],
// TODO: Remove ignored rules and fix the code
"@typescript-eslint/no-explicit-any": "off",
"@typescript-eslint/no-this-alias": "off",
"@typescript-eslint/no-unused-vars": "off",
"@typescript-eslint/no-var-requires": "off",
"no-undef": "off",
"no-unreachable": "off",
Expand Down
71 changes: 37 additions & 34 deletions examples/express-sample/app.js
Original file line number Diff line number Diff line change
@@ -1,57 +1,60 @@
var config = require('config');
var config = require("config");

if (config.Raygun.Key === 'YOUR_API_KEY') {
console.error('You need to set your Raygun API key in the config file');
process.exit(1);
if (config.Raygun.Key === "YOUR_API_KEY") {
console.error("You need to set your Raygun API key in the config file");
process.exit(1);
}

// Setup Raygun
var raygun = require('raygun');
var raygun = require("raygun");
var raygunClient = new raygun.Client().init({
apiKey: config.Raygun.Key
apiKey: config.Raygun.Key,
});

var express = require('express');
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
var sassMiddleware = require('node-sass-middleware');
var express = require("express");
var path = require("path");
var logger = require("morgan");
var cookieParser = require("cookie-parser");
var bodyParser = require("body-parser");
var sassMiddleware = require("node-sass-middleware");

var routes = require('./routes/index');
var users = require('./routes/users');
var routes = require("./routes/index");
var users = require("./routes/users");

var app = express();

// Set the user if we have one
raygunClient.user = function(req) {
return '[email protected]';
raygunClient.user = function (req) {
return "[email protected]";
};

// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'ejs');
app.set("views", path.join(__dirname, "views"));
app.set("view engine", "ejs");

// uncomment after placing your favicon in /public
//app.use(favicon(__dirname + '/public/favicon.ico'));
app.use(logger('dev'));
app.use(logger("dev"));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({
extended: false
}));
app.use(
bodyParser.urlencoded({
extended: false,
}),
);
app.use(cookieParser());
app.use(sassMiddleware({
src: __dirname,
dest: path.join(__dirname, 'public'),
debug: true,
outputStyle: 'compressed',
prefix: '/stylesheets'
}));
app.use(express.static(path.join(__dirname, 'public')));

app.use('/', routes);
app.use('/users', users);
app.use(
sassMiddleware({
src: __dirname,
dest: path.join(__dirname, "public"),
debug: true,
outputStyle: "compressed",
prefix: "/stylesheets",
}),
);
app.use(express.static(path.join(__dirname, "public")));

app.use("/", routes);
app.use("/users", users);

// Add the Raygun Express handler
app.use(raygunClient.expressHandler);
Expand Down
7 changes: 4 additions & 3 deletions examples/express-sample/package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

70 changes: 35 additions & 35 deletions examples/using-domains/app.js
Original file line number Diff line number Diff line change
@@ -1,52 +1,52 @@
var config = require('config');
var config = require("config");

if (config.Raygun.Key === 'YOUR_API_KEY') {
console.error('You need to set your Raygun API key in the config file');
process.exit(1);
if (config.Raygun.Key === "YOUR_API_KEY") {
console.error("You need to set your Raygun API key in the config file");
process.exit(1);
}

// Setup Raygun
var raygun = require('raygun');
var raygunClient = new raygun.Client().init({apiKey: config.Raygun.Key});
var raygun = require("raygun");
var raygunClient = new raygun.Client().init({ apiKey: config.Raygun.Key });

// Create a domain
var appDomain = require('domain').create();
var appDomain = require("domain").create();

// Add the error handler so we can pass errors to Raygun when the domain
// crashes
appDomain.on('error', function (err) {
try {
console.log(`Domain error caught: ${err}`);
// Try send data to Raygun
raygunClient.send(err, {}, function () {
// Exit the process once the error has been sent
console.log('Error sent to Raygun, exiting process');
process.exit(1);
});
} catch (e) {
// If there was an error sending to Raygun, log it out and end the process.
// Could possibly log out to a text file here
console.log(e);
process.exit(1);
}
appDomain.on("error", function (err) {
try {
console.log(`Domain error caught: ${err}`);
// Try send data to Raygun
raygunClient.send(err, {}, function () {
// Exit the process once the error has been sent
console.log("Error sent to Raygun, exiting process");
process.exit(1);
});
} catch (e) {
// If there was an error sending to Raygun, log it out and end the process.
// Could possibly log out to a text file here
console.log(e);
process.exit(1);
}
});

// Run the domain
appDomain.run(function () {
var fs = require('fs');
var fs = require("fs");

console.log('Running example app');
console.log("Running example app");

// Try and read a file that doesn't exist
fs.readFile('badfile.json', 'utf8', function (err, file) {
if (err) {
// We could send the error straight to Raygun
// raygunClient.send(err);
// Try and read a file that doesn't exist
fs.readFile("badfile.json", "utf8", function (err, file) {
if (err) {
// We could send the error straight to Raygun
// raygunClient.send(err);

// Or we can deal with it in our "Fake Error Handler" below
// Or we can deal with it in our "Fake Error Handler" below

// This will throw an error as fakeErrorHandler doesn't exist
fakeErrorHandler.DealWith(err);
}
})
});
// This will throw an error as fakeErrorHandler doesn't exist
fakeErrorHandler.DealWith(err);
}
});
});
17 changes: 8 additions & 9 deletions lib/raygun.batch.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@ import type { IncomingMessage } from "http";
import {
callVariadicCallback,
Callback,
Message,
HTTPOptions,
SendOptions,
} from "./types";
Expand Down Expand Up @@ -32,7 +31,7 @@ export const MAX_BATCH_SIZE_BYTES = 1638400;
const MAX_BATCH_INNER_SIZE_BYTES = MAX_BATCH_SIZE_BYTES - 2; // for the starting and ending byte

export class RaygunBatchTransport {
private timerId: any | null = null;
private timerId: NodeJS.Timeout | null = null;
private httpOptions: HTTPOptions;
private interval: number;
private batchId: number = 0;
Expand Down Expand Up @@ -65,15 +64,15 @@ export class RaygunBatchTransport {
}

private onIncomingMessage(messageAndCallback: MessageAndCallback) {
const { serializedMessage, callback } = messageAndCallback;
const { serializedMessage } = messageAndCallback;
const messageLength = Buffer.byteLength(serializedMessage, "utf-8");

if (messageLength >= MAX_BATCH_INNER_SIZE_BYTES) {
const messageSize = Math.ceil(messageLength / 1024);
const startOfMessage = serializedMessage.slice(0, 1000);

console.warn(
`[raygun4node] Error is too large to send to Raygun (${messageSize}kb)\nStart of error: ${startOfMessage}`
`[raygun4node] Error is too large to send to Raygun (${messageSize}kb)\nStart of error: ${startOfMessage}`,
);

return;
Expand Down Expand Up @@ -124,7 +123,7 @@ export class RaygunBatchTransport {
const { payload, messageCount, callbacks } = batch;

debug(
`batch transport - processing ( ${messageCount} message(s) in batch)`
`batch transport - processing ( ${messageCount} message(s) in batch)`,
);

const batchId = this.batchId;
Expand All @@ -133,16 +132,16 @@ export class RaygunBatchTransport {

const runAllCallbacks = (
err: Error | null,
response: IncomingMessage | null
response: IncomingMessage | null,
) => {
const durationInMs = stopTimer();
if (err) {
debug(
`batch transport - error sending batch (id=${batchId}, duration=${durationInMs}ms): ${err}`
`batch transport - error sending batch (id=${batchId}, duration=${durationInMs}ms): ${err}`,
);
} else {
debug(
`batch transport - successfully sent batch (id=${batchId}, duration=${durationInMs}ms)`
`batch transport - successfully sent batch (id=${batchId}, duration=${durationInMs}ms)`,
);
}

Expand All @@ -154,7 +153,7 @@ export class RaygunBatchTransport {
};

debug(
`batch transport - sending batch (id=${batchId}) (${messageCount} messages, ${payload.length} bytes)`
`batch transport - sending batch (id=${batchId}) (${messageCount} messages, ${payload.length} bytes)`,
);

const stopTimer = startTimer();
Expand Down
18 changes: 11 additions & 7 deletions lib/raygun.messageBuilder.ts
Original file line number Diff line number Diff line change
Expand Up @@ -31,23 +31,26 @@ type UserMessageData = RawUserData | string | undefined;
const humanString = require("object-to-human-string");
const packageDetails = require("../package.json");

function filterKeys(obj: { [key: string]: any }, filters: string[]) {
function filterKeys(obj: object, filters: string[]): object {
if (!obj || !filters || typeof obj !== "object") {
return obj;
}
// Make temporary copy of the object to avoid mutating the original
// Cast to Record<string, object> to enforce type check and avoid using any
const _obj = { ...obj } as Record<string, object>;
Object.keys(obj).forEach(function (i) {
if (filters.indexOf(i) > -1) {
delete obj[i];
delete _obj[i];
} else {
obj[i] = filterKeys(obj[i], filters);
_obj[i] = filterKeys(_obj[i], filters);
}
});
return obj;
return _obj;
}

function getStackTrace(
error: Error,
options: MessageBuilderOptions
options: MessageBuilderOptions,
): StackFrame[] {
const stack: StackFrame[] = [];
const trace = stackTrace.parse(error);
Expand Down Expand Up @@ -75,7 +78,7 @@ function getStackTrace(

function buildError(
error: IndexableError,
options: MessageBuilderOptions
options: MessageBuilderOptions,
): BuiltError {
const builtError: BuiltError = {
stackTrace: getStackTrace(error, options),
Expand Down Expand Up @@ -126,7 +129,8 @@ export class RaygunMessageBuilder {
return this.message as Message;
}

setErrorDetails(error: any) {
// eslint-disable-next-line @typescript-eslint/no-explicit-any
setErrorDetails(error: Error | string | any) {
if (
!(error instanceof Error) &&
typeof error !== "string" &&
Expand Down
Loading