blob: f40841895cb0a7c831b156cc825e8a3c1aa6465d [file] [log] [blame]
// Copyright (c) 2017, the Dart project authors. Please see the AUTHORS file
// for details. All rights reserved. Use of this source code is governed by a
// BSD-style license that can be found in the LICENSE file.
/// @assertion Future<Link> rename(String newPath)
/// Renames this link.
///
/// Returns a `Future<Link>` that completes with a [Link] for the renamed link.
///
/// If [newPath] identifies an existing file or link, that entity is removed
/// first. If [newPath] identifies an existing directory then the future
/// completes with a [FileSystemException].
///
/// @note Shortly:
/// - [File]/[Link] `rename/renameSync` can replace other [File]/[Link] but not
/// [Directory]
/// - [Directory] `rename/renameSync` can not replace an existing
/// [File]/[Link]/[Directory] except on POSIX where it can replace an empty
/// [Directory]
/// In order to create a symbolic link on Windows, Dart must be run in
/// Administrator mode or the system must have Developer Mode enabled, otherwise
/// a [FileSystemException] will be raised with `ERROR_PRIVILEGE_NOT_HELD` set
/// as the errno when this call is made.
///
/// @description Checks that if [newPath] identifies an existing link to a
/// directory, that link is replaced. The link being renamed is a link to a
/// directory
/// @author sgrekhov@unipro.ru
/// @issue 30687
import "dart:io";
import "../../../Utils/expect.dart";
import "../file_utils.dart";
main() async {
await inSandbox(_main);
}
void _main(Directory sandbox) async {
Link link = getTempLinkSync(parent: sandbox);
Link target = getTempLinkSync(parent: sandbox, target: sandbox.path);
String oldTarget = link.targetSync();
asyncStart();
await link.rename(target.path).then((renamed) {
Expect.equals(target.path, renamed.path);
Expect.isTrue(renamed.existsSync());
Expect.isFalse(link.existsSync());
Expect.equals(oldTarget, renamed.targetSync());
asyncEnd();
});
}