@invarn/cibuild 1.3.17 → 1.3.18

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../src/config.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAkB3C,wBAAgB,UAAU,CAAC,UAAU,CAAC,EAAE,MAAM,GAAG,QAAQ,CA6BxD"}
1
+ {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../src/config.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAmB3C,wBAAgB,UAAU,CAAC,UAAU,CAAC,EAAE,MAAM,GAAG,QAAQ,CA6BxD"}
@@ -12,6 +12,7 @@ const DEFAULT_CONFIG = {
12
12
  paths: {
13
13
  buildsDir: ".ci-builds",
14
14
  cacheDir: ".ci-cache",
15
+ peerCacheDir: "peer",
15
16
  derivedDataDir: "~/Library/Developer/Xcode/DerivedData",
16
17
  },
17
18
  };
@@ -24,6 +24,7 @@ export interface CIConfig {
24
24
  paths: {
25
25
  buildsDir: string;
26
26
  cacheDir: string;
27
+ peerCacheDir?: string;
27
28
  derivedDataDir: string;
28
29
  };
29
30
  /** When true, steps that require remote infrastructure (S3, servers) skip gracefully */
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,OAAO;IACtB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,QAAQ,GAAG,QAAQ,GAAG,MAAM,GAAG,MAAM,CAAC;IAC5C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,OAAO,CAAC;CACvB;AAED,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,EAAE,CAAC;IACpB,KAAK,EAAE,OAAO,EAAE,CAAC;IACjB,UAAU,EAAE,MAAM,EAAE,CAAC;CACtB;AAED,MAAM,WAAW,QAAQ;IACvB,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,EAAE;QACZ,MAAM,EAAE,MAAM,CAAC;QACf,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,EAAE,MAAM,CAAC;KACd,CAAC;IACF,iBAAiB,EAAE,MAAM,CAAC;IAC1B,KAAK,EAAE;QACL,SAAS,EAAE,MAAM,CAAC;QAClB,QAAQ,EAAE,MAAM,CAAC;QACjB,cAAc,EAAE,MAAM,CAAC;KACxB,CAAC;IACF,wFAAwF;IACxF,KAAK,CAAC,EAAE,OAAO,CAAC;CACjB;AAED,MAAM,WAAW,YAAY;IAC3B,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI,CAAC;IACpF,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI,CAAC;IACpE,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI,CAAC;IAClE,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI,CAAC;CACnE;AAED,MAAM,WAAW,eAAe;IAC9B,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC;IACjC,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,YAAY,KAAK,IAAI,GAAG,IAAI,CAAC;IAChD,UAAU,CAAC,GAAG,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC;CACjC;AAED,MAAM,MAAM,eAAe,GAAG,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC,GAAG,EAAE,eAAe,KAAK,IAAI,KAAK,WAAW,CAAC"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,OAAO;IACtB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,QAAQ,GAAG,QAAQ,GAAG,MAAM,GAAG,MAAM,CAAC;IAC5C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,OAAO,CAAC;CACvB;AAED,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,EAAE,MAAM,EAAE,CAAC;IACpB,KAAK,EAAE,OAAO,EAAE,CAAC;IACjB,UAAU,EAAE,MAAM,EAAE,CAAC;CACtB;AAED,MAAM,WAAW,QAAQ;IACvB,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,EAAE;QACZ,MAAM,EAAE,MAAM,CAAC;QACf,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,EAAE,MAAM,CAAC;KACd,CAAC;IACF,iBAAiB,EAAE,MAAM,CAAC;IAC1B,KAAK,EAAE;QACL,SAAS,EAAE,MAAM,CAAC;QAClB,QAAQ,EAAE,MAAM,CAAC;QACjB,YAAY,CAAC,EAAE,MAAM,CAAC;QACtB,cAAc,EAAE,MAAM,CAAC;KACxB,CAAC;IACF,wFAAwF;IACxF,KAAK,CAAC,EAAE,OAAO,CAAC;CACjB;AAED,MAAM,WAAW,YAAY;IAC3B,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI,CAAC;IACpF,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI,CAAC;IACpE,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI,CAAC;IAClE,IAAI,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI,CAAC;CACnE;AAED,MAAM,WAAW,eAAe;IAC9B,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC;IACjC,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,YAAY,KAAK,IAAI,GAAG,IAAI,CAAC;IAChD,UAAU,CAAC,GAAG,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC;CACjC;AAED,MAAM,MAAM,eAAe,GAAG,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC,GAAG,EAAE,eAAe,KAAK,IAAI,KAAK,WAAW,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"cache.d.ts","sourceRoot":"","sources":["../../../../src/yaml/steps/cache.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAC7C,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAExD;;;;GAIG;AACH,MAAM,WAAW,WAAW;IAC1B,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,EAAE,MAAM,EAAE,CAAC;CACjB;AAED,eAAO,MAAM,aAAa,EAAE,MAAM,CAAC,MAAM,EAAE,WAAW,CAQrD,CAAC;AAEF;;GAEG;AACH,MAAM,WAAW,eAAe;IAC9B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,aAAa,CAAC,EAAE,OAAO,CAAC;CACzB;AAED;;GAEG;AACH,MAAM,WAAW,eAAe;IAC9B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,qBAAqB,CAAC,EAAE,OAAO,CAAC;CACjC;AAED;;;GAGG;AACH,qBAAa,qBAAsB,SAAQ,gBAAgB;IACnD,OAAO,CAAC,MAAM,EAAE,eAAe,EAAE,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,EAAE,QAAQ,GAAG,OAAO,CAAC,OAAO,CAAC;YAoGzF,iBAAiB;CAoEhC;AAED;;;GAGG;AACH,qBAAa,qBAAsB,SAAQ,gBAAgB;IACnD,OAAO,CAAC,MAAM,EAAE,eAAe,EAAE,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,EAAE,QAAQ,GAAG,OAAO,CAAC,OAAO,CAAC;YAwJzF,iBAAiB;CA0EhC"}
1
+ {"version":3,"file":"cache.d.ts","sourceRoot":"","sources":["../../../../src/yaml/steps/cache.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,gBAAgB,EAAE,MAAM,WAAW,CAAC;AAC7C,OAAO,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAExD;;;;GAIG;AACH,MAAM,WAAW,WAAW;IAC1B,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,EAAE,MAAM,EAAE,CAAC;CACjB;AAED,eAAO,MAAM,aAAa,EAAE,MAAM,CAAC,MAAM,EAAE,WAAW,CASrD,CAAC;AAEF;;GAEG;AACH,MAAM,WAAW,eAAe;IAC9B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,aAAa,CAAC,EAAE,OAAO,CAAC;CACzB;AAED;;GAEG;AACH,MAAM,WAAW,eAAe;IAC9B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,qBAAqB,CAAC,EAAE,OAAO,CAAC;CACjC;AAED;;;GAGG;AACH,qBAAa,qBAAsB,SAAQ,gBAAgB;IACnD,OAAO,CAAC,MAAM,EAAE,eAAe,EAAE,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,EAAE,QAAQ,GAAG,OAAO,CAAC,OAAO,CAAC;YAoGzF,iBAAiB;CAoEhC;AAED;;;GAGG;AACH,qBAAa,qBAAsB,SAAQ,gBAAgB;IACnD,OAAO,CAAC,MAAM,EAAE,eAAe,EAAE,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,EAAE,QAAQ,GAAG,OAAO,CAAC,OAAO,CAAC;YAwJzF,iBAAiB;CA0EhC"}
@@ -5,8 +5,9 @@ import { BaseStepExecutor } from './base.js';
5
5
  export const CACHE_PRESETS = {
6
6
  cocoapods: { lockfile: 'Podfile.lock', keyPrefix: 'pods', paths: ['Pods'] },
7
7
  carthage: { lockfile: 'Cartfile.resolved', keyPrefix: 'carthage', paths: ['Carthage'] },
8
- spm: { lockfile: 'Package.resolved', keyPrefix: 'spm', paths: ['.build'] },
9
- gradle: { lockfile: 'gradle/wrapper/gradle-wrapper.properties', keyPrefix: 'gradle', paths: ['~/.gradle/caches'] },
8
+ spm: { lockfile: 'Package.resolved', keyPrefix: 'spm', paths: ['~/Library/Developer/Xcode/DerivedData/*/SourcePackages'] },
9
+ gradle: { lockfile: 'gradle/wrapper/gradle-wrapper.properties', keyPrefix: 'gradle', paths: ['~/.gradle/caches', '~/.gradle/wrapper/dists'] },
10
+ kmm: { lockfile: 'gradle/wrapper/gradle-wrapper.properties', keyPrefix: 'kmm', paths: ['~/.gradle/caches', '~/.gradle/wrapper/dists', '~/.konan'] },
10
11
  npm: { lockfile: 'package-lock.json', keyPrefix: 'npm', paths: ['node_modules'] },
11
12
  yarn: { lockfile: 'yarn.lock', keyPrefix: 'yarn', paths: ['node_modules'] },
12
13
  dart: { lockfile: 'pubspec.lock', keyPrefix: 'dart', paths: ['.dart_tool', '.pub-cache'] },
@@ -58,7 +59,7 @@ export class CachePullStepExecutor extends BaseStepExecutor {
58
59
  // Generate cache file name based on cache key
59
60
  commands.push('');
60
61
  commands.push('# Generate cache file path');
61
- commands.push(`CACHE_FILE="$CACHE_DIR/${this.escapeBash(cacheKey)}.tar.gz"`);
62
+ commands.push(`CACHE_FILE="$CACHE_DIR/${this.escapeBash(cacheKey)}.tar.zst"`);
62
63
  if (isDebugMode) {
63
64
  commands.push('echo "Debug mode enabled"');
64
65
  commands.push('echo "Cache file: $CACHE_FILE"');
@@ -72,7 +73,7 @@ export class CachePullStepExecutor extends BaseStepExecutor {
72
73
  commands.push(' echo "Cache file size: $(du -h "$CACHE_FILE" | cut -f1)"');
73
74
  }
74
75
  // Extract cache
75
- commands.push(' tar -xzf "$CACHE_FILE" -C /');
76
+ commands.push(' zstd -dc "$CACHE_FILE" | tar -xf - -C /');
76
77
  commands.push(' echo "Cache restored successfully"');
77
78
  // List restored paths if debug mode
78
79
  if (isDebugMode && Array.isArray(cachePaths) && cachePaths.length > 0) {
@@ -123,14 +124,14 @@ export class CachePullStepExecutor extends BaseStepExecutor {
123
124
  commands.push('echo "Lockfile: $LOCKFILE"');
124
125
  commands.push('echo "Cache key: $CACHE_KEY"');
125
126
  }
126
- commands.push('CACHE_FILE="$CACHE_DIR/$CACHE_KEY.tar.gz"');
127
+ commands.push('CACHE_FILE="$CACHE_DIR/$CACHE_KEY.tar.zst"');
127
128
  commands.push('');
128
129
  commands.push('if [ -f "$CACHE_FILE" ]; then');
129
130
  commands.push(' echo "Cache found, extracting..."');
130
131
  if (isDebugMode) {
131
132
  commands.push(' echo "Cache file size: $(du -h "$CACHE_FILE" | cut -f1)"');
132
133
  }
133
- commands.push(' tar -xzf "$CACHE_FILE" -C /');
134
+ commands.push(' zstd -dc "$CACHE_FILE" | tar -xf - -C /');
134
135
  commands.push(' echo "Cache restored successfully"');
135
136
  if (isDebugMode) {
136
137
  commands.push(' echo "Restored paths:"');
@@ -204,7 +205,7 @@ export class CachePushStepExecutor extends BaseStepExecutor {
204
205
  // Generate cache file name based on cache key
205
206
  commands.push('');
206
207
  commands.push('# Generate cache file path');
207
- commands.push(`CACHE_FILE="$CACHE_DIR/${this.escapeBash(cacheKey)}.tar.gz"`);
208
+ commands.push(`CACHE_FILE="$CACHE_DIR/${this.escapeBash(cacheKey)}.tar.zst"`);
208
209
  if (isDebugMode) {
209
210
  commands.push('echo "Debug mode enabled"');
210
211
  commands.push('echo "Cache file: $CACHE_FILE"');
@@ -267,7 +268,7 @@ export class CachePushStepExecutor extends BaseStepExecutor {
267
268
  commands.push(' echo "Paths to cache:"');
268
269
  commands.push(' printf " %s\\n" "${PATHS_TO_CACHE[@]}"');
269
270
  }
270
- commands.push(' tar -czf "$CACHE_FILE" "${PATHS_TO_CACHE[@]}" 2>/dev/null || true');
271
+ commands.push(' tar -cf - "${PATHS_TO_CACHE[@]}" 2>/dev/null | zstd -3 > "$CACHE_FILE.tmp" && mv "$CACHE_FILE.tmp" "$CACHE_FILE" || true');
271
272
  commands.push(' if [ -f "$CACHE_FILE" ]; then');
272
273
  commands.push(' echo "Cache created successfully"');
273
274
  if (isDebugMode) {
@@ -311,7 +312,7 @@ export class CachePushStepExecutor extends BaseStepExecutor {
311
312
  commands.push('echo "Lockfile: $LOCKFILE"');
312
313
  commands.push('echo "Cache key: $CACHE_KEY"');
313
314
  }
314
- commands.push('CACHE_FILE="$CACHE_DIR/$CACHE_KEY.tar.gz"');
315
+ commands.push('CACHE_FILE="$CACHE_DIR/$CACHE_KEY.tar.zst"');
315
316
  commands.push('');
316
317
  // Collect paths to cache
317
318
  commands.push('# Collect paths to cache');
@@ -332,7 +333,7 @@ export class CachePushStepExecutor extends BaseStepExecutor {
332
333
  // Create cache archive
333
334
  commands.push('if [ ${#PATHS_TO_CACHE[@]} -gt 0 ]; then');
334
335
  commands.push(' echo "Caching ${#PATHS_TO_CACHE[@]} path(s)..."');
335
- commands.push(' tar -czf "$CACHE_FILE" "${PATHS_TO_CACHE[@]}" 2>/dev/null || true');
336
+ commands.push(' tar -cf - "${PATHS_TO_CACHE[@]}" 2>/dev/null | zstd -3 > "$CACHE_FILE.tmp" && mv "$CACHE_FILE.tmp" "$CACHE_FILE" || true');
336
337
  commands.push(' if [ -f "$CACHE_FILE" ]; then');
337
338
  commands.push(' echo "Cache created successfully"');
338
339
  if (isDebugMode) {
@@ -171,6 +171,20 @@ describe('Step Implementations', () => {
171
171
  expect(result.script).toContain('yarn.lock');
172
172
  expect(result.script).toContain('yarn-');
173
173
  });
174
+ test('should auto-configure for kmm technology', async () => {
175
+ const executor = new CachePullStepExecutor();
176
+ const result = await executor.execute({ technology: 'kmm' }, {}, testConfig);
177
+ expect(result.script).toContain('gradle/wrapper/gradle-wrapper.properties');
178
+ expect(result.script).toContain('kmm-');
179
+ });
180
+ test('should use zstd compression format', async () => {
181
+ const executor = new CachePullStepExecutor();
182
+ const result = await executor.execute({ technology: 'cocoapods' }, {}, testConfig);
183
+ expect(result.script).toContain('.tar.zst');
184
+ expect(result.script).toContain('zstd -dc');
185
+ expect(result.script).not.toContain('.tar.gz');
186
+ expect(result.script).not.toContain('tar -xzf');
187
+ });
174
188
  test('should throw on unknown technology', async () => {
175
189
  const executor = new CachePullStepExecutor();
176
190
  await expect(executor.execute({ technology: 'unknown' }, {}, testConfig)).rejects.toThrow("Unknown cache technology 'unknown'");
@@ -222,7 +236,7 @@ describe('Step Implementations', () => {
222
236
  expect(result.script).toContain('Podfile.lock');
223
237
  expect(result.script).toContain('pods-');
224
238
  expect(result.script).toContain('Pods');
225
- expect(result.script).toContain('tar -czf');
239
+ expect(result.script).toContain('zstd -3');
226
240
  });
227
241
  test('should auto-configure for gradle technology', async () => {
228
242
  const executor = new CachePushStepExecutor();
@@ -243,6 +257,23 @@ describe('Step Implementations', () => {
243
257
  expect(result.script).toContain('.dart_tool');
244
258
  expect(result.script).toContain('.pub-cache');
245
259
  });
260
+ test('should auto-configure for kmm technology', async () => {
261
+ const executor = new CachePushStepExecutor();
262
+ const result = await executor.execute({ technology: 'kmm' }, {}, testConfig);
263
+ expect(result.script).toContain('gradle/wrapper/gradle-wrapper.properties');
264
+ expect(result.script).toContain('kmm-');
265
+ expect(result.script).toContain('~/.gradle/caches');
266
+ expect(result.script).toContain('~/.gradle/wrapper/dists');
267
+ expect(result.script).toContain('~/.konan');
268
+ });
269
+ test('should use zstd compression format', async () => {
270
+ const executor = new CachePushStepExecutor();
271
+ const result = await executor.execute({ technology: 'cocoapods' }, {}, testConfig);
272
+ expect(result.script).toContain('.tar.zst');
273
+ expect(result.script).toContain('zstd -3');
274
+ expect(result.script).not.toContain('.tar.gz');
275
+ expect(result.script).not.toContain('tar -czf');
276
+ });
246
277
  test('should throw on unknown technology', async () => {
247
278
  const executor = new CachePushStepExecutor();
248
279
  await expect(executor.execute({ technology: 'unknown' }, {}, testConfig)).rejects.toThrow("Unknown cache technology 'unknown'");
@@ -1 +1 @@
1
- {"version":3,"file":"test-config.d.ts","sourceRoot":"","sources":["../../../../src/yaml/steps/test-config.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAE/C,eAAO,MAAM,UAAU,EAAE,QAcxB,CAAC"}
1
+ {"version":3,"file":"test-config.d.ts","sourceRoot":"","sources":["../../../../src/yaml/steps/test-config.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAE/C,eAAO,MAAM,UAAU,EAAE,QAexB,CAAC"}
@@ -10,6 +10,7 @@ export const testConfig = {
10
10
  paths: {
11
11
  buildsDir: '.ci-builds',
12
12
  cacheDir: '.ci-cache',
13
+ peerCacheDir: 'peer',
13
14
  derivedDataDir: '~/Library/Developer/Xcode/DerivedData',
14
15
  },
15
16
  };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@invarn/cibuild",
3
- "version": "1.3.17",
3
+ "version": "1.3.18",
4
4
  "description": "CI Build CLI — local pipeline orchestration and validation",
5
5
  "type": "module",
6
6
  "main": "dist/cli.cjs",