Compare commits
14 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 18b976abab | |||
| 9841953e8f | |||
| 7d8606daef | |||
| 9ef20a7667 | |||
| 8228d17a30 | |||
| 057d7926be | |||
| 72a10dcb4b | |||
| 5dbf81ca0f | |||
| 80f5e33f36 | |||
| 8301255dd6 | |||
| dbb2c8891b | |||
| 1fc25ff1d8 | |||
| fc34eb502d | |||
| d2febe2b18 |
+1
-1
@@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"featureCode": "manual",
|
"featureCode": "manual",
|
||||||
"syncDate": "2026-04-24T22:40:04.295Z",
|
"syncDate": "2026-04-24T23:45:06.978Z",
|
||||||
"filesSynced": 12
|
"filesSynced": 12
|
||||||
}
|
}
|
||||||
@@ -30,15 +30,29 @@ function buildSyncBranchName(featureCode) {
|
|||||||
|
|
||||||
function mapAppsScriptFileToRepoPath(file) {
|
function mapAppsScriptFileToRepoPath(file) {
|
||||||
if (!file || !file.name || !file.type) return null;
|
if (!file || !file.name || !file.type) return null;
|
||||||
|
|
||||||
if (file.name === 'appsscript' && file.type === 'JSON') {
|
if (file.name === 'appsscript' && file.type === 'JSON') {
|
||||||
return 'appsscript.json';
|
return 'appsscript.json';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const appFiles = ['Code', 'Index', 'styles', 'scripts'];
|
||||||
|
const docsFiles = ['Readme'];
|
||||||
|
|
||||||
|
let prefix = 'workflow/';
|
||||||
|
if (appFiles.includes(file.name)) {
|
||||||
|
prefix = 'app/';
|
||||||
|
} else if (docsFiles.includes(file.name)) {
|
||||||
|
prefix = 'docs/';
|
||||||
|
}
|
||||||
|
|
||||||
if (file.type === 'SERVER_JS') {
|
if (file.type === 'SERVER_JS') {
|
||||||
return 'src/' + file.name + '.gs';
|
return prefix + file.name + '.gs';
|
||||||
}
|
}
|
||||||
if (file.type === 'HTML') {
|
if (file.type === 'HTML') {
|
||||||
return 'src/' + file.name + '.html';
|
return prefix + file.name + '.html';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Logger.log('Unknown file type for mapping: ' + file.name + ' (' + file.type + ')');
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -373,6 +387,7 @@ function runManualSyncToGitea() {
|
|||||||
console.log('=== Sync Summary ===');
|
console.log('=== Sync Summary ===');
|
||||||
console.log('Branch Sync: ' + res.branch);
|
console.log('Branch Sync: ' + res.branch);
|
||||||
console.log('Files: ' + res.summary.created + ' created, ' + res.summary.updated + ' updated, ' + res.summary.errors + ' errors.');
|
console.log('Files: ' + res.summary.created + ' created, ' + res.summary.updated + ' updated, ' + res.summary.errors + ' errors.');
|
||||||
|
console.log('Catatan: File baru akan menggunakan path app/, docs/, dan workflow/. File lama dengan folder src/ mungkin masih tertinggal di repositori (Gitea) dan harus dihapus secara manual.');
|
||||||
if (res.pullRequest) {
|
if (res.pullRequest) {
|
||||||
console.log('Pull Request Status: ' + (res.pullRequest.existed ? 'Existing' : 'Created'));
|
console.log('Pull Request Status: ' + (res.pullRequest.existed ? 'Existing' : 'Created'));
|
||||||
console.log('Pull Request URL: ' + res.pullRequest.url);
|
console.log('Pull Request URL: ' + res.pullRequest.url);
|
||||||
@@ -384,3 +399,4 @@ function runManualSyncToGitea() {
|
|||||||
}
|
}
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -472,9 +472,11 @@ function testGiteaPathMapping() {
|
|||||||
|
|
||||||
const testCases = [
|
const testCases = [
|
||||||
{ input: { name: 'appsscript', type: 'JSON' }, expected: 'appsscript.json' },
|
{ input: { name: 'appsscript', type: 'JSON' }, expected: 'appsscript.json' },
|
||||||
{ input: { name: 'Code', type: 'SERVER_JS' }, expected: 'src/Code.gs' },
|
{ input: { name: 'Code', type: 'SERVER_JS' }, expected: 'app/Code.gs' },
|
||||||
{ input: { name: 'Index', type: 'HTML' }, expected: 'src/Index.html' },
|
{ input: { name: 'Index', type: 'HTML' }, expected: 'app/Index.html' },
|
||||||
{ input: { name: 'styles', type: 'HTML' }, expected: 'src/styles.html' },
|
{ input: { name: 'styles', type: 'HTML' }, expected: 'app/styles.html' },
|
||||||
|
{ input: { name: 'Readme', type: 'SERVER_JS' }, expected: 'docs/Readme.gs' },
|
||||||
|
{ input: { name: 'WorkflowConfig', type: 'SERVER_JS' }, expected: 'workflow/WorkflowConfig.gs' },
|
||||||
{ input: { name: 'Unknown', type: 'OTHER' }, expected: null }
|
{ input: { name: 'Unknown', type: 'OTHER' }, expected: null }
|
||||||
];
|
];
|
||||||
|
|
||||||
@@ -554,7 +556,7 @@ function testPrepareGitSyncPayload() {
|
|||||||
{ name: 'Code', type: 'SERVER_JS', source: 'function test() {}' },
|
{ name: 'Code', type: 'SERVER_JS', source: 'function test() {}' },
|
||||||
{ name: 'Index', type: 'HTML', source: '<html></html>' },
|
{ name: 'Index', type: 'HTML', source: '<html></html>' },
|
||||||
{ name: 'InvalidFile', type: 'UNKNOWN', source: 'junk' },
|
{ name: 'InvalidFile', type: 'UNKNOWN', source: 'junk' },
|
||||||
{ name: 'MissingSource', type: 'SERVER_JS' }, // valid file type mapping, missing source resolves to empty string
|
{ name: 'MissingSource', type: 'SERVER_JS' },
|
||||||
null
|
null
|
||||||
];
|
];
|
||||||
|
|
||||||
@@ -566,13 +568,14 @@ function testPrepareGitSyncPayload() {
|
|||||||
|
|
||||||
assertEqual_('Valid files mapped correctly', payload.files.length, 4);
|
assertEqual_('Valid files mapped correctly', payload.files.length, 4);
|
||||||
assertEqual_('JSON mapped to appsscript.json', payload.files[0].repoPath, 'appsscript.json');
|
assertEqual_('JSON mapped to appsscript.json', payload.files[0].repoPath, 'appsscript.json');
|
||||||
assertEqual_('SERVER_JS mapped to src/Code.gs', payload.files[1].repoPath, 'src/Code.gs');
|
assertEqual_('SERVER_JS mapped to app/Code.gs', payload.files[1].repoPath, 'app/Code.gs');
|
||||||
assertEqual_('HTML mapped to src/Index.html', payload.files[2].repoPath, 'src/Index.html');
|
assertEqual_('HTML mapped to app/Index.html', payload.files[2].repoPath, 'app/Index.html');
|
||||||
assertEqual_('SERVER_JS missing source mapped to src/MissingSource.gs', payload.files[3].repoPath, 'src/MissingSource.gs');
|
assertEqual_('SERVER_JS missing source mapped to workflow/MissingSource.gs', payload.files[3].repoPath, 'workflow/MissingSource.gs');
|
||||||
|
|
||||||
console.log('--- Test Passed: Prepare Git Sync Payload ---');
|
console.log('--- Test Passed: Prepare Git Sync Payload ---');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
function testGiteaSyncHelpers() {
|
function testGiteaSyncHelpers() {
|
||||||
console.log('--- Starting Test: Gitea Sync Helpers ---');
|
console.log('--- Starting Test: Gitea Sync Helpers ---');
|
||||||
|
|
||||||
@@ -612,7 +615,7 @@ function testSyncSummaryFormat() {
|
|||||||
updated: 1,
|
updated: 1,
|
||||||
errors: 0,
|
errors: 0,
|
||||||
details: [
|
details: [
|
||||||
{ file: "src/Code.gs", ok: true, message: "" },
|
{ file: "app/Code.gs", ok: true, message: "" },
|
||||||
{ file: "appsscript.json", ok: true, message: "" },
|
{ file: "appsscript.json", ok: true, message: "" },
|
||||||
{ file: "sync-manifest.json", ok: true, message: "" }
|
{ file: "sync-manifest.json", ok: true, message: "" }
|
||||||
]
|
]
|
||||||
@@ -637,6 +640,8 @@ function testSyncSummaryFormat() {
|
|||||||
|
|
||||||
console.log('--- Test Passed: Sync Summary Format ---');
|
console.log('--- Test Passed: Sync Summary Format ---');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
function testGetAppsScriptProjectContentErrorFormat() {
|
function testGetAppsScriptProjectContentErrorFormat() {
|
||||||
console.log('--- Starting Test: Get Apps Script Project Content Error Format ---');
|
console.log('--- Starting Test: Get Apps Script Project Content Error Format ---');
|
||||||
|
|
||||||
Reference in New Issue
Block a user