Fix formatting and update linter.

This commit is contained in:
Carter Bertolini 2023-10-24 16:55:11 -04:00
parent e8dc16ad7d
commit 51a58fc322
6 changed files with 156 additions and 170 deletions

View File

@ -12,14 +12,14 @@ module.exports = {
rules: { rules: {
"array-callback-return": "error", "array-callback-return": "error",
"no-await-in-loop": "error", "no-await-in-loop": "error",
"no-cond-assign": [ "error", "always" ], "no-cond-assign": ["error", "always"],
"no-constant-binary-expression": "error", "no-constant-binary-expression": "error",
"no-constant-condition": "error", "no-constant-condition": "error",
"no-constructor-return": "error", "no-constructor-return": "error",
"no-duplicate-imports": "error", "no-duplicate-imports": "error",
"no-promise-executor-return": "error", "no-promise-executor-return": "error",
"no-self-compare": "error", "no-self-compare": "error",
"no-undef": [ "error", { "typeof": true } ], "no-undef": ["error", { "typeof": true }],
"no-unmodified-loop-condition": "error", "no-unmodified-loop-condition": "error",
"no-unreachable-loop": "error", "no-unreachable-loop": "error",
"no-unused-private-class-members": "error", "no-unused-private-class-members": "error",
@ -27,14 +27,14 @@ module.exports = {
"accessor-pairs": "error", "accessor-pairs": "error",
"block-scoped-var": "error", "block-scoped-var": "error",
"curly": [ "error", "all" ], "curly": ["error", "all"],
"default-case": "error", "default-case": "error",
"default-case-last": "error", "default-case-last": "error",
"default-param-last": "error", "default-param-last": "error",
"dot-notation": "error", "dot-notation": "error",
"eqeqeq": "error", "eqeqeq": "error",
"func-style": [ "error", "expression" ], "func-style": ["error", "expression"],
"grouped-accessor-pairs": [ "error", "getBeforeSet" ], "grouped-accessor-pairs": ["error", "getBeforeSet"],
"no-caller": "error", "no-caller": "error",
"no-console": "error", "no-console": "error",
"no-eq-null": "error", "no-eq-null": "error",
@ -84,8 +84,8 @@ module.exports = {
"no-useless-rename": "error", "no-useless-rename": "error",
"no-var": "error", "no-var": "error",
"no-void": "error", "no-void": "error",
"one-var": [ "error", "never" ], "one-var": ["error", "never"],
"one-var-declaration-per-line": [ "error", "always" ], "one-var-declaration-per-line": ["error", "always"],
"prefer-arrow-callback": "error", "prefer-arrow-callback": "error",
"prefer-const": "error", "prefer-const": "error",
"prefer-exponentiation-operator": "error", "prefer-exponentiation-operator": "error",
@ -98,39 +98,40 @@ module.exports = {
"prefer-rest-params": "error", "prefer-rest-params": "error",
"prefer-spread": "error", "prefer-spread": "error",
"prefer-template": "error", "prefer-template": "error",
"quote-props": [ "error", "as-needed" ], "quote-props": ["error", "as-needed"],
"semi": ["error", "always"],
"radix": "error", "radix": "error",
"require-await": "error", "require-await": "error",
"require-unicode-regexp": "error", "require-unicode-regexp": "error",
"symbol-description": "error", "symbol-description": "error",
"yoda": "error", "yoda": "error",
"array-bracket-newline": [ "error", "consistent" ], "array-bracket-newline": ["error", "consistent"],
"array-bracket-spacing": [ "error", "always", { "singleValue": false } ], "array-bracket-spacing": ["error", "always", { "singleValue": false }],
"array-element-newline": [ "error", "consistent" ], "array-element-newline": ["error", "consistent"],
"arrow-parens": "error", "arrow-parens": "error",
"arrow-spacing": "error", "arrow-spacing": "error",
"block-spacing": "error", "block-spacing": "error",
"computed-property-spacing": "error", "computed-property-spacing": "error",
"eol-last": "error", "eol-last": "error",
"generator-star-spacing": [ "error", { "before": false, "after": true } ], "generator-star-spacing": ["error", { "before": false, "after": true }],
"key-spacing": "error", "key-spacing": "error",
"linebreak-style": "error", "linebreak-style": "error",
"lines-around-comment": [ "error", { "allowBlockStart": true }], "lines-around-comment": ["error", { "allowBlockStart": true }],
"max-len": [ "error", { "code": 120 } ], "max-len": ["error", { "code": 120 }],
"new-parens": "error", "new-parens": "error",
"no-multi-spaces": "error", "no-multi-spaces": "error",
"no-multiple-empty-lines": "error", "no-multiple-empty-lines": "error",
"no-trailing-spaces": "error", "no-trailing-spaces": "error",
"no-whitespace-before-property": "error", "no-whitespace-before-property": "error",
"nonblock-statement-body-position": [ "error", "below" ], "nonblock-statement-body-position": ["error", "below"],
"object-curly-newline": [ "error", { "ObjectExpression": { "consistent": true }, "ObjectPattern": { "consistent": true } } ], "object-curly-newline": ["error", { "ObjectExpression": { "consistent": true }, "ObjectPattern": { "consistent": true } }],
"operator-linebreak": "error", "operator-linebreak": "error",
"padded-blocks": [ "error", "never" ], "padded-blocks": ["error", "never"],
"space-in-parens": "error", "space-in-parens": "error",
"switch-colon-spacing": [ "error", { "after": false, "before": false } ], "switch-colon-spacing": ["error", { "after": false, "before": false }],
"template-curly-spacing": "error", "template-curly-spacing": "error",
"wrap-iife": "error", "wrap-iife": "error",
"yield-star-spacing": [ "error", "after" ], "yield-star-spacing": ["error", "after"],
} }
}; };

View File

@ -1,9 +1,9 @@
import Alpaca from '@alpacahq/alpaca-trade-api' import Alpaca from '@alpacahq/alpaca-trade-api';
import { AlpacaPortfolioProvider } from './portfolio' import { AlpacaPortfolioProvider } from './portfolio';
import { AlpacaQuoteProvider } from './quote' import { AlpacaQuoteProvider } from './quote';
import { Exchange } from '../interface/exchange' import { Exchange } from '../interface/exchange';
import { PortfolioProvider } from '../interface/portfolio' import { PortfolioProvider } from '../interface/portfolio';
import { QuoteProvider } from '../interface/quote' import { QuoteProvider } from '../interface/quote';
/** /**
* Exchange implementation for Alpaca. * Exchange implementation for Alpaca.

View File

@ -1,4 +1,4 @@
import Alpaca from '@alpacahq/alpaca-trade-api' import Alpaca from '@alpacahq/alpaca-trade-api';
import { PortfolioProvider, Portfolio, Position } from '../interface/portfolio'; import { PortfolioProvider, Portfolio, Position } from '../interface/portfolio';
/** /**
@ -50,7 +50,7 @@ export class AlpacaPortfolioProvider implements PortfolioProvider {
); );
})); }));
}); });
} };
/** /**
* Creates a new AlpacaPortfolioProvider instance. * Creates a new AlpacaPortfolioProvider instance.

View File

@ -1,4 +1,4 @@
import Alpaca from '@alpacahq/alpaca-trade-api' import Alpaca from '@alpacahq/alpaca-trade-api';
import { QuoteProvider, Quote } from '../interface/quote'; import { QuoteProvider, Quote } from '../interface/quote';
/** /**
@ -27,8 +27,8 @@ export class AlpacaQuoteProvider implements QuoteProvider {
); );
}).catch((err) => { }).catch((err) => {
return err; return err;
}) });
} };
/** /**
* Creates a new AlpacaQuoteProvider instance. * Creates a new AlpacaQuoteProvider instance.

View File

@ -9,4 +9,4 @@ export {
PortfolioProvider, PortfolioProvider,
Quote, Quote,
QuoteProvider QuoteProvider
} };

View File

@ -1,34 +1,19 @@
import { describe, expect, test } from '@jest/globals'; import { describe, expect, test } from '@jest/globals';
import 'dotenv/config' import 'dotenv/config';
import { AlpacaExchange } from '../src/alpaca/exchange' import { AlpacaExchange } from '../src/alpaca/exchange';
import { createLogger, transports, format } from "winston";
const logger = createLogger({
transports: [new transports.Console()],
format: format.combine(
format.colorize(),
format.timestamp(),
format.printf(({ timestamp, level, message, service }) => {
return `[${timestamp}] ${service} ${level}: ${message}`;
})
),
defaultMeta: {
service: "AlpacaTest",
},
});
describe('Alpaca Tests', () => { describe('Alpaca Tests', () => {
test('portfolio fetch', () => { test('portfolio fetch', () => {
expect(process.env.ALPACA_API_KEY).toBeDefined(); expect(process.env.ALPACA_API_KEY).toBeDefined();
expect(process.env.ALPACA_SECRET_KEY).toBeDefined(); expect(process.env.ALPACA_SECRET_KEY).toBeDefined();
let exchange = new AlpacaExchange(process.env.ALPACA_API_KEY!, process.env.ALPACA_SECRET_KEY!, true); const exchange = new AlpacaExchange(process.env.ALPACA_API_KEY!, process.env.ALPACA_SECRET_KEY!, true);
expect(exchange.portfolioProvider.fetchPortfolio()).resolves; expect(exchange.portfolioProvider.fetchPortfolio()).resolves.toBeDefined();
}); });
test('quote fetch', async () => { test('quote fetch', () => {
expect(process.env.ALPACA_API_KEY).toBeDefined(); expect(process.env.ALPACA_API_KEY).toBeDefined();
expect(process.env.ALPACA_SECRET_KEY).toBeDefined(); expect(process.env.ALPACA_SECRET_KEY).toBeDefined();
let exchange = new AlpacaExchange(process.env.ALPACA_API_KEY!, process.env.ALPACA_SECRET_KEY!, true); const exchange = new AlpacaExchange(process.env.ALPACA_API_KEY!, process.env.ALPACA_SECRET_KEY!, true);
expect(exchange.quoteProvider.fetchQuote("AAPL")).resolves; expect(exchange.quoteProvider.fetchQuote("AAPL")).resolves.toBeDefined();
}); });
}); });