cleanup
This commit is contained in:
@@ -1,5 +1,5 @@
|
||||
import { existsSync, } from 'fs'
|
||||
import { lstat, readFile } from 'fs/promises'
|
||||
import { lstat, readFile,rm } from 'fs/promises'
|
||||
import git from 'git-client'
|
||||
import { resolve } from 'path'
|
||||
import int from 'set.prototype.intersection';
|
||||
@@ -10,7 +10,7 @@ import { FILTER_LIST } from './FILTER_LIST.mjs';
|
||||
* @returns {Promise<[string,string|null]>} second argument is null if ineligible for slicing
|
||||
*/
|
||||
export async function cloneRepoAndCheck([repoName, repoGitUrl, downloadCount]) {
|
||||
const repoPath = resolve('cache/repos', repoName)
|
||||
const repoPath = resolve('../cache-repos/repos', repoName)
|
||||
|
||||
if (FILTER_LIST.includes(repoGitUrl)) {
|
||||
console.log("[git] ignoring ", repoName)
|
||||
@@ -19,9 +19,11 @@ export async function cloneRepoAndCheck([repoName, repoGitUrl, downloadCount]) {
|
||||
// console.log('[git] fetching',repoName, repoGitUrl);
|
||||
await cacheCloneIdempotently(repoPath, repoName, repoGitUrl)
|
||||
|
||||
const tsConfigFileLocation = resolve(repoPath,'tsconfig.json');
|
||||
const tsConfigFileLocation = resolve(repoPath, 'tsconfig.json');
|
||||
const tsConfigFileExists = existsSync(tsConfigFileLocation);
|
||||
if(tsConfigFileExists) return [repoName, null];
|
||||
if (tsConfigFileExists){
|
||||
return [repoName, null];
|
||||
}
|
||||
|
||||
|
||||
const packageFile = resolve(repoPath, 'package.json')
|
||||
@@ -31,14 +33,15 @@ export async function cloneRepoAndCheck([repoName, repoGitUrl, downloadCount]) {
|
||||
// console.log(packageJSONContentsString);
|
||||
const packageJSONContents = JSON.parse(packageJSONContentsString)
|
||||
// console.log(repoName, packageJSONContents.license)
|
||||
if(!hasAnyActualDependencies(packageJSONContents, repoName)) {
|
||||
console.log("[git] skipping", repoName, "has no dependencies");
|
||||
if (!hasAnyActualDependencies(packageJSONContents, repoName)) {
|
||||
// console.log("[git] skipping", repoName, "has no dependencies");
|
||||
return [repoName, null];
|
||||
}
|
||||
|
||||
const hasDependencies = checkTestingDependencies(packageJSONContents, repoName);
|
||||
if (hasDependencies)
|
||||
if (hasDependencies) {
|
||||
return [repoName, ((packageJSONContents?.scripts?.test))]
|
||||
}
|
||||
else return [repoName, null]
|
||||
}
|
||||
function hasAnyActualDependencies(packageJSONContents, repoName) {
|
||||
@@ -49,7 +52,7 @@ function hasAnyActualDependencies(packageJSONContents, repoName) {
|
||||
}
|
||||
|
||||
function checkTestingDependencies(packageJSONContents, repoName) {
|
||||
const testingLibraries = new Set(['mocha', 'istanbul']);
|
||||
const testingLibraries = new Set(['mocha']);
|
||||
const dependencies = new Set();
|
||||
if (packageJSONContents.dependencies !== undefined) {
|
||||
for (const dep of Object.keys(packageJSONContents.dependencies)) {
|
||||
@@ -78,10 +81,10 @@ async function cacheCloneIdempotently(repoPath, repoName, repoGitUrl) {
|
||||
if (!isDir) throw new Error(repoName, " is mangled. delete directory and re-clone.")
|
||||
else {
|
||||
// const path = await git.status({ $cwd: repoPath })
|
||||
|
||||
|
||||
}
|
||||
} else {
|
||||
console.log("[git] cloning", repoGitUrl);
|
||||
await git.clone(repoGitUrl, repoPath,{'single-branch':true,depth:1})
|
||||
await git.clone(repoGitUrl, repoPath, { 'single-branch': true, depth: 1 })
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user