From 54b79ade65bfe3749e9ec2cd4fc52f6a74c26e94 Mon Sep 17 00:00:00 2001 From: Sachin Grover Date: Wed, 5 Feb 2020 02:27:56 +0530 Subject: [PATCH] fix(@angular-devkit/core): Rename to a non-existing dir Added unit test and requested changes. Fixes #16484 --- packages/angular_devkit/core/node/host.ts | 5 +++++ packages/angular_devkit/core/node/host_spec.ts | 16 ++++++++++++++++ 2 files changed, 21 insertions(+) diff --git a/packages/angular_devkit/core/node/host.ts b/packages/angular_devkit/core/node/host.ts index 27e716fc2a41..5db3fb399bcd 100644 --- a/packages/angular_devkit/core/node/host.ts +++ b/packages/angular_devkit/core/node/host.ts @@ -6,6 +6,7 @@ * found in the LICENSE file at https://angular.io/license */ import * as fs from 'fs'; +import * as path from 'path'; import { Observable, concat, from as observableFrom, of, throwError } from 'rxjs'; import { concatMap, @@ -316,6 +317,10 @@ export class NodeJsSyncHost implements virtualFs.Host { // TODO: remove this try+catch when issue https://github.com/ReactiveX/rxjs/issues/3740 is // fixed. try { + const toSystemPath = getSystemPath(to); + if (!fs.existsSync(path.dirname(toSystemPath))) { + fs.mkdirSync(path.dirname(toSystemPath), { recursive: true }); + } fs.renameSync(getSystemPath(from), getSystemPath(to)); obs.next(); obs.complete(); diff --git a/packages/angular_devkit/core/node/host_spec.ts b/packages/angular_devkit/core/node/host_spec.ts index 1b55218d64f9..7ac9615b5db3 100644 --- a/packages/angular_devkit/core/node/host_spec.ts +++ b/packages/angular_devkit/core/node/host_spec.ts @@ -108,4 +108,20 @@ describe('NodeJsSyncHost', () => { .then(done, done.fail); }, 30000); + linuxOnlyIt('rename to a non-existing dir', done => { + + Promise.resolve() + .then(() => fs.mkdirSync(root + '/rename')) + .then(() => fs.writeFileSync(root + '/rename/a.txt', 'hello world')) + .then(() => { + host.rename(normalize('/rename/a.txt'), normalize('/rename/b/c/d/a.txt')); + if (fs.existsSync(root + '/rename/b/c/d/a.txt')) { + const resContent = host.read(normalize('/rename/b/c/d/a.txt')); + const content = virtualFs.fileBufferToString(resContent); + expect(content).toEqual('hello world'); + } + }) + .then(done, done.fail); + }, 30000); + });