This commit is contained in:
caesar
2025-01-16 09:06:11 +08:00
parent 5348ca237b
commit 484116be5c
7 changed files with 3830 additions and 88 deletions

17
dist/utils.js vendored
View File

@@ -7,14 +7,19 @@ exports.post = exports.doesAnyPatternMatch = exports.split_message = void 0;
const http_1 = __importDefault(require("http")); const http_1 = __importDefault(require("http"));
const https_1 = __importDefault(require("https")); const https_1 = __importDefault(require("https"));
function split_message(files) { function split_message(files) {
files = files || "";
let n = files.includes('\n') || files.includes('\r');
files = files.trim(); files = files.trim();
if (!files) { let res = [];
let t = files.split("\n"); if (files) {
if (t.length > 0) if (n) {
return t.map(str => str.trim()).filter(item => item !== null && item !== undefined && item !== ""); res = files.split(/[\r\n]/);
return files.split(",").map(str => str.trim()).filter(item => item !== null && item !== undefined && item !== ""); }
else {
res = files.split(",");
}
} }
return []; return res.map(str => str.trim()).filter(item => item !== null && item !== undefined && item !== "");
} }
exports.split_message = split_message; exports.split_message = split_message;
function doesAnyPatternMatch(patterns, str) { function doesAnyPatternMatch(patterns, str) {

4
jest.config.js Normal file
View File

@@ -0,0 +1,4 @@
module.exports = {
preset: 'ts-jest',
testEnvironment: 'node',
};

3854
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@@ -6,9 +6,10 @@
"build": "tsc" "build": "tsc"
}, },
"devDependencies": { "devDependencies": {
"@types/jest": "^29.5.14",
"@types/node": "^22.10.6", "@types/node": "^22.10.6",
"jest": "^29.7.0",
"ts-jest": "^29.2.5",
"typescript": "^4.5.4" "typescript": "^4.5.4"
},
"dependencies": {
} }
} }

View File

@@ -1,14 +1,19 @@
import http from "http"; import http from "http";
import https from "https"; import https from "https";
export function split_message(files: string) { export function split_message(files: string): string[] {
files = files || "";
let n = files.includes('\n') || files.includes('\r');
files = files.trim() files = files.trim()
if (!files) { let res: string[] = [];
let t = files.split("\n"); if (files) {
if (t.length > 0) return t.map(str => str.trim()).filter(item => item !== null && item !== undefined && item !== ""); if (n) {
return files.split(",").map(str => str.trim()).filter(item => item !== null && item !== undefined && item !== "") res = files.split(/[\r\n]/);
} else {
res = files.split(",")
}
} }
return [] return res.map(str => str.trim()).filter(item => item !== null && item !== undefined && item !== "")
} }
export function doesAnyPatternMatch(patterns: Array<string>, str: string) { export function doesAnyPatternMatch(patterns: Array<string>, str: string) {

View File

@@ -0,0 +1,16 @@
// split_message.test.ts
import {doesAnyPatternMatch, split_message} from '../src/utils';
describe('split_message', () => {
it('include readme.md', () => {
const testString = `^.+\\.md
test2\\.js
dist/.*
`;
expect(doesAnyPatternMatch(split_message(testString),"readme.md")).toBe(true);
expect(doesAnyPatternMatch(split_message(testString),"dist/index.js")).toBe(true);
expect(doesAnyPatternMatch(split_message(testString),"dist/prompt.js")).toBe(true);
expect(doesAnyPatternMatch(split_message(testString),"src/index.js")).toBe(false);
});
});

View File

@@ -5,7 +5,8 @@
"node_modules/@types" "node_modules/@types"
], ],
"types": [ "types": [
"node" "node",
"jest"
], ],
"target": "ES2020", "target": "ES2020",
// 编译目标 // 编译目标
@@ -30,4 +31,4 @@
"**/*.spec.ts" "**/*.spec.ts"
// 排除测试文件 // 排除测试文件
] ]
} }