diff --git a/storage/storagefileiov9jstest/BUILD.gn b/storage/storagefileiov9jstest/BUILD.gn
index bb9aa3f7be1ea18abd4cbc19a811bbb0bd6f3506..96f6917438ee0382ae35d318b5dcc671dd4da8a3 100644
--- a/storage/storagefileiov9jstest/BUILD.gn
+++ b/storage/storagefileiov9jstest/BUILD.gn
@@ -1,4 +1,4 @@
-# Copyright (c) 2023 Huawei Device Co., Ltd.
+# Copyright (C) 2022 Huawei Device Co., Ltd.
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
@@ -13,11 +13,23 @@
import("//test/xts/tools/build/suite.gni")
-ohos_js_app_suite("storagefileiov9_js_test") {
- test_hap = true
- testonly = true
+ohos_js_hap_suite("storagefileiov9_js_test") {
+ hap_profile = "./src/main/config.json"
+ deps = [
+ ":storagefileiov9_js_assets",
+ ":storagefileiov9_js_resources",
+ ]
+ certificate_profile = "./signature/openharmony_sx.p7b"
hap_name = "ActsStorageFileIoV9JSTest"
subsystem_name = "filemanagement"
part_name = "file_api"
- certificate_profile = "./signature/openharmony_sx.p7b"
+}
+ohos_js_assets("storagefileiov9_js_assets") {
+ js2abc = true
+ hap_profile = "./src/main/config.json"
+ source_dir = "./src/main/js"
+}
+ohos_resources("storagefileiov9_js_resources") {
+ sources = [ "./src/main/resources" ]
+ hap_profile = "./src/main/config.json"
}
diff --git a/storage/storagefileiov9jstest/Test.json b/storage/storagefileiov9jstest/Test.json
index 71cd2cfc53386e099129b39755d51bbed5fc06e2..58245887d6b3806d64a06f263b85488eb1228a71 100644
--- a/storage/storagefileiov9jstest/Test.json
+++ b/storage/storagefileiov9jstest/Test.json
@@ -1,17 +1,17 @@
-{
- "description": "Configuration for storage filefs Tests",
- "driver": {
- "type": "OHJSUnitTest",
- "test-timeout": "600000",
- "shell-timeout": "600000",
- "bundle-name": "ohos.acts.storage.fileiov9",
- "package-name": "ohos.acts.storage.fileiov9_test"
- },
- "kits": [
- {
- "test-file-name": ["ActsStorageFileIoV9JSTest.hap"],
- "type": "AppInstallKit",
- "cleanup-apps": true
- }
- ]
+{
+ "description": "Configuration for storage filefs Tests",
+ "driver": {
+ "type": "OHJSUnitTest",
+ "test-timeout": "600000",
+ "shell-timeout": "600000",
+ "bundle-name": "ohos.acts.storage.fileiov9",
+ "package-name": "ohos.acts.storage.fileiov9"
+ },
+ "kits": [
+ {
+ "test-file-name": ["ActsStorageFileIoV9JSTest.hap"],
+ "type": "AppInstallKit",
+ "cleanup-apps": true
+ }
+ ]
}
\ No newline at end of file
diff --git a/storage/storagefileiov9jstest/build-profile.json5 b/storage/storagefileiov9jstest/build-profile.json5
deleted file mode 100644
index 7715cddc0112e0e0c8e40623b77ff67b82731829..0000000000000000000000000000000000000000
--- a/storage/storagefileiov9jstest/build-profile.json5
+++ /dev/null
@@ -1,42 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-{
- "app": {
- "signingConfigs": [
- ],
- "compileSdkVersion": 10,
- "compatibleSdkVersion": 10,
- "products": [
- {
- "name": "default",
- "signingConfig": "default"
- }
- ]
- },
- "modules": [
- {
- "name": "entry",
- "srcPath": "./entry",
- "targets": [
- {
- "name": "default",
- "applyToProducts": [
- "default"
- ]
- }
- ]
- }
- ]
-}
\ No newline at end of file
diff --git a/storage/storagefileiov9jstest/entry/build-profile.json5 b/storage/storagefileiov9jstest/entry/build-profile.json5
deleted file mode 100644
index a6a17e6971173aacea7b75d9ae897a80d335dc0b..0000000000000000000000000000000000000000
--- a/storage/storagefileiov9jstest/entry/build-profile.json5
+++ /dev/null
@@ -1,27 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-{
- "apiType": 'faMode',
- "buildOption": {
- },
- "targets": [
- {
- "name": "default",
- },
- {
- "name": "ohosTest",
- }
- ]
-}
\ No newline at end of file
diff --git a/storage/storagefileiov9jstest/entry/hvigorfile.ts b/storage/storagefileiov9jstest/entry/hvigorfile.ts
deleted file mode 100644
index 89d831db3f5a6431ef4f9078128ad61b6ae36c48..0000000000000000000000000000000000000000
--- a/storage/storagefileiov9jstest/entry/hvigorfile.ts
+++ /dev/null
@@ -1,16 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-// Script for compiling build behavior. It is built in the build plug-in and cannot be modified currently.
-export { legacyHapTasks } from '@ohos/hvigor-ohos-plugin';
diff --git a/storage/storagefileiov9jstest/entry/oh-package.json5 b/storage/storagefileiov9jstest/entry/oh-package.json5
deleted file mode 100644
index 75ca1d70feb1c490379299fe342058a2a7183388..0000000000000000000000000000000000000000
--- a/storage/storagefileiov9jstest/entry/oh-package.json5
+++ /dev/null
@@ -1,24 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-{
- "license": "",
- "devDependencies": {},
- "author": "",
- "name": "entry",
- "description": "Please describe the basic information.",
- "main": "",
- "version": "1.0.0",
- "dependencies": {}
-}
diff --git a/storage/storagefileiov9jstest/entry/src/main/config.json b/storage/storagefileiov9jstest/entry/src/main/config.json
deleted file mode 100644
index 0d0aaf4730f3fb34e97aa789122d97b1ee6ed926..0000000000000000000000000000000000000000
--- a/storage/storagefileiov9jstest/entry/src/main/config.json
+++ /dev/null
@@ -1,65 +0,0 @@
-{
- "app":{
- "bundleName":"ohos.acts.storage.fileiov9",
- "vendor":"example",
- "version":{
- "code":1000000,
- "name":"1.0.0"
- }
- },
- "deviceConfig":{
-
- },
- "module":{
- "package":"ohos.acts.storage.fileiov9",
- "name":".entry",
- "mainAbility":".MainAbility",
- "deviceType":[
- "default",
- "tablet"
- ],
- "distro":{
- "deliveryWithInstall":true,
- "installationFree":true,
- "moduleName":"entry",
- "moduleType":"entry"
- },
- "abilities":[
- {
- "description":"$string:MainAbility_desc",
- "formsEnabled":false,
- "icon":"$media:icon",
- "label":"$string:MainAbility_label",
- "launchType":"standard",
- "name":".MainAbility",
- "orientation":"unspecified",
- "skills":[
- {
- "actions":[
- "action.system.home"
- ],
- "entities":[
- "entity.system.home"
- ]
- }
- ],
- "srcLanguage":"js",
- "srcPath":"MainAbility",
- "type":"page",
- "visible":true
- }
- ],
- "js":[
- {
- "name":".MainAbility",
- "pages":[
- "pages/index/index"
- ],
- "window":{
- "autoDesignWidth":false,
- "designWidth":720
- }
- }
- ]
- }
-}
\ No newline at end of file
diff --git a/storage/storagefileiov9jstest/entry/src/main/js/MainAbility/app.js b/storage/storagefileiov9jstest/entry/src/main/js/MainAbility/app.js
deleted file mode 100644
index 8c9a4fce93b5e76779bdf446c49269a5a51db98a..0000000000000000000000000000000000000000
--- a/storage/storagefileiov9jstest/entry/src/main/js/MainAbility/app.js
+++ /dev/null
@@ -1,26 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-import hilog from '@ohos.hilog';
-export default {
- onCreate() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'Application onCreate');
- },
- onDestroy() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'Application onDestroy');
- },
-}
-
-
-
diff --git a/storage/storagefileiov9jstest/entry/src/main/js/MainAbility/pages/index/index.css b/storage/storagefileiov9jstest/entry/src/main/js/MainAbility/pages/index/index.css
deleted file mode 100644
index a711febae0b34889547cd72fbe5f8cc3e0bd043c..0000000000000000000000000000000000000000
--- a/storage/storagefileiov9jstest/entry/src/main/js/MainAbility/pages/index/index.css
+++ /dev/null
@@ -1,60 +0,0 @@
-/*
- * Copyright (c) 2022 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-.container {
- flex-direction: column;
- justify-content: center;
- align-items: center;
- width: 100%;
- height: 100%;
-}
-
-.title {
- font-size: 40px;
- color: #000000;
- opacity: 0.9;
-}
-
-@media screen and (device-type: tablet) and (orientation: landscape) {
- .title {
- font-size: 100px;
- }
-}
-
-@media screen and (device-type: wearable) {
- .title {
- font-size: 28px;
- color: #FFFFFF;
- }
-}
-
-@media screen and (device-type: tv) {
- .container {
- background-image: url("/common/images/Wallpaper.png");
- background-size: cover;
- background-repeat: no-repeat;
- background-position: center;
- }
-
- .title {
- font-size: 100px;
- color: #FFFFFF;
- }
-}
-
-@media screen and (device-type: phone) and (orientation: landscape) {
- .title {
- font-size: 60px;
- }
-}
diff --git a/storage/storagefileiov9jstest/entry/src/main/js/MainAbility/pages/index/index.hml b/storage/storagefileiov9jstest/entry/src/main/js/MainAbility/pages/index/index.hml
deleted file mode 100644
index 95bd1e877b3fa9f5f4e4dc0ff608591b540d116d..0000000000000000000000000000000000000000
--- a/storage/storagefileiov9jstest/entry/src/main/js/MainAbility/pages/index/index.hml
+++ /dev/null
@@ -1,19 +0,0 @@
-/*
- * Copyright (c) 2022 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-
- {{ $t('strings.hello') }} {{ title }}
-
-
diff --git a/storage/storagefileiov9jstest/entry/src/main/js/MainAbility/pages/index/index.js b/storage/storagefileiov9jstest/entry/src/main/js/MainAbility/pages/index/index.js
deleted file mode 100644
index f086298302bd6362b079bf99cf40dfa1e00d85e9..0000000000000000000000000000000000000000
--- a/storage/storagefileiov9jstest/entry/src/main/js/MainAbility/pages/index/index.js
+++ /dev/null
@@ -1,22 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-export default {
- data: {
- title: ""
- },
- onInit() {
- this.title = this.$t('strings.world');
- }
-}
diff --git a/storage/storagefileiov9jstest/entry/src/main/resources/base/element/string.json b/storage/storagefileiov9jstest/entry/src/main/resources/base/element/string.json
deleted file mode 100644
index 3f9ba4d59ec455e0d468a529ede22b8c6aab5ed9..0000000000000000000000000000000000000000
--- a/storage/storagefileiov9jstest/entry/src/main/resources/base/element/string.json
+++ /dev/null
@@ -1,28 +0,0 @@
-{
- "string": [
- {
- "name": "app_name",
- "value": "storagefilefsjstest"
- },
- {
- "name": "mainability_description",
- "value": "JS_Phone_Empty Feature Ability"
- },
- {
- "name": "MainAbility_desc",
- "value": "description"
- },
- {
- "name": "MainAbility_label",
- "value": "label"
- },
- {
- "name": "TestAbility_desc",
- "value": "description"
- },
- {
- "name": "TestAbility_label",
- "value": "label"
- }
- ]
-}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/config.json b/storage/storagefileiov9jstest/entry/src/ohosTest/config.json
deleted file mode 100644
index 8a5e2a5d59719f7c29c4c985b4cb025971073c4e..0000000000000000000000000000000000000000
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/config.json
+++ /dev/null
@@ -1,69 +0,0 @@
-{
- "app":{
- "bundleName":"ohos.acts.storage.fileiov9",
- "vendor":"example",
- "version":{
- "code":1000000,
- "name":"1.0.0"
- }
- },
- "deviceConfig":{
-
- },
- "module":{
- "package":"ohos.acts.storage.fileiov9_test",
- "name":".entry_test",
- "mainAbility":".TestAbility",
- "deviceType":[
- "default",
- "tablet"
- ],
- "testRunner":{
- "name":"OpenHarmonyTestRunner",
- "srcPath":"TestRunner"
- },
- "distro":{
- "deliveryWithInstall":true,
- "installationFree":true,
- "moduleName":"entry_test",
- "moduleType":"feature"
- },
- "abilities":[
- {
- "description":"$string:TestAbility_desc",
- "formsEnabled":false,
- "icon":"$media:icon",
- "label":"$string:TestAbility_label",
- "launchType":"standard",
- "name":".TestAbility",
- "orientation":"unspecified",
- "skills":[
- {
- "actions":[
- "action.system.home"
- ],
- "entities":[
- "entity.system.home"
- ]
- }
- ],
- "srcLanguage":"js",
- "srcPath":"TestAbility",
- "type":"page",
- "visible":true
- }
- ],
- "js":[
- {
- "name":".TestAbility",
- "pages":[
- "pages/index/index"
- ],
- "window":{
- "autoDesignWidth":false,
- "designWidth":720
- }
- }
- ]
- }
-}
\ No newline at end of file
diff --git a/storage/storagefileiov9jstest/hvigor/hvigor-config.json5 b/storage/storagefileiov9jstest/hvigor/hvigor-config.json5
deleted file mode 100644
index d1ed6c3c0cb895265a376515209a0575aeb7d898..0000000000000000000000000000000000000000
--- a/storage/storagefileiov9jstest/hvigor/hvigor-config.json5
+++ /dev/null
@@ -1,20 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-{
- "hvigorVersion": "2.0.0",
- "dependencies": {
- "@ohos/hvigor-ohos-plugin": "2.0.0"
- }
-}
diff --git a/storage/storagefileiov9jstest/hvigor/hvigor-wrapper.js b/storage/storagefileiov9jstest/hvigor/hvigor-wrapper.js
deleted file mode 100644
index 2507619ca768432ff3fb806441f29eff47a4c4f0..0000000000000000000000000000000000000000
--- a/storage/storagefileiov9jstest/hvigor/hvigor-wrapper.js
+++ /dev/null
@@ -1,16 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-"use strict";var e=require("fs"),t=require("path"),n=require("os"),r=require("crypto"),u=require("child_process"),o=require("constants"),i=require("stream"),s=require("util"),c=require("assert"),a=require("tty"),l=require("zlib"),f=require("net");function d(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var D=d(e),p=d(t),E=d(n),m=d(r),h=d(u),y=d(o),C=d(i),F=d(s),g=d(c),A=d(a),v=d(l),S=d(f),w="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{},O={},b={},_={},B=w&&w.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(_,"__esModule",{value:!0}),_.isMac=_.isLinux=_.isWindows=void 0;const P=B(E.default),k="Windows_NT",x="Linux",N="Darwin";_.isWindows=function(){return P.default.type()===k},_.isLinux=function(){return P.default.type()===x},_.isMac=function(){return P.default.type()===N};var I={},T=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),R=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),M=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)"default"!==n&&Object.prototype.hasOwnProperty.call(e,n)&&T(t,e,n);return R(t,e),t};Object.defineProperty(I,"__esModule",{value:!0}),I.hash=void 0;const L=M(m.default);I.hash=function(e,t="md5"){return L.createHash(t).update(e,"utf-8").digest("hex")},function(e){var t=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),n=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),r=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var r={};if(null!=e)for(var u in e)"default"!==u&&Object.prototype.hasOwnProperty.call(e,u)&&t(r,e,u);return n(r,e),r};Object.defineProperty(e,"__esModule",{value:!0}),e.HVIGOR_BOOT_JS_FILE_PATH=e.HVIGOR_PROJECT_DEPENDENCY_PACKAGE_JSON_PATH=e.HVIGOR_PROJECT_DEPENDENCIES_HOME=e.HVIGOR_PROJECT_WRAPPER_HOME=e.HVIGOR_PROJECT_NAME=e.HVIGOR_PROJECT_ROOT_DIR=e.HVIGOR_PROJECT_CACHES_HOME=e.HVIGOR_PNPM_STORE_PATH=e.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH=e.HVIGOR_WRAPPER_TOOLS_HOME=e.HVIGOR_USER_HOME=e.DEFAULT_PACKAGE_JSON=e.DEFAULT_HVIGOR_CONFIG_JSON_FILE_NAME=e.PNPM=e.HVIGOR=e.NPM_TOOL=e.PNPM_TOOL=e.HVIGOR_ENGINE_PACKAGE_NAME=void 0;const u=r(p.default),o=r(E.default),i=_,s=I;e.HVIGOR_ENGINE_PACKAGE_NAME="@ohos/hvigor",e.PNPM_TOOL=(0,i.isWindows)()?"pnpm.cmd":"pnpm",e.NPM_TOOL=(0,i.isWindows)()?"npm.cmd":"npm",e.HVIGOR="hvigor",e.PNPM="pnpm",e.DEFAULT_HVIGOR_CONFIG_JSON_FILE_NAME="hvigor-config.json5",e.DEFAULT_PACKAGE_JSON="package.json",e.HVIGOR_USER_HOME=u.resolve(o.homedir(),".hvigor"),e.HVIGOR_WRAPPER_TOOLS_HOME=u.resolve(e.HVIGOR_USER_HOME,"wrapper","tools"),e.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH=u.resolve(e.HVIGOR_WRAPPER_TOOLS_HOME,"node_modules",".bin",e.PNPM_TOOL),e.HVIGOR_PNPM_STORE_PATH=u.resolve(e.HVIGOR_USER_HOME,"caches"),e.HVIGOR_PROJECT_CACHES_HOME=u.resolve(e.HVIGOR_USER_HOME,"project_caches"),e.HVIGOR_PROJECT_ROOT_DIR=process.cwd(),e.HVIGOR_PROJECT_NAME=u.basename((0,s.hash)(e.HVIGOR_PROJECT_ROOT_DIR)),e.HVIGOR_PROJECT_WRAPPER_HOME=u.resolve(e.HVIGOR_PROJECT_ROOT_DIR,e.HVIGOR),e.HVIGOR_PROJECT_DEPENDENCIES_HOME=u.resolve(e.HVIGOR_PROJECT_CACHES_HOME,e.HVIGOR_PROJECT_NAME,"workspace"),e.HVIGOR_PROJECT_DEPENDENCY_PACKAGE_JSON_PATH=u.resolve(e.HVIGOR_PROJECT_DEPENDENCIES_HOME,e.DEFAULT_PACKAGE_JSON),e.HVIGOR_BOOT_JS_FILE_PATH=u.resolve(e.HVIGOR_PROJECT_DEPENDENCIES_HOME,"node_modules","@ohos","hvigor","bin","hvigor.js")}(b);var j={},$={};Object.defineProperty($,"__esModule",{value:!0}),$.logInfoPrintConsole=$.logErrorAndExit=void 0,$.logErrorAndExit=function(e){e instanceof Error?console.error(e.message):console.error(e),process.exit(-1)},$.logInfoPrintConsole=function(e){console.log(e)};var H=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),J=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),G=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)"default"!==n&&Object.prototype.hasOwnProperty.call(e,n)&&H(t,e,n);return J(t,e),t},V=w&&w.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(j,"__esModule",{value:!0}),j.isFileExists=j.offlinePluginConversion=j.executeCommand=j.getNpmPath=j.hasNpmPackInPaths=void 0;const U=h.default,W=G(p.default),z=b,K=$,q=V(D.default);j.hasNpmPackInPaths=function(e,t){try{return require.resolve(e,{paths:[...t]}),!0}catch(e){return!1}},j.getNpmPath=function(){const e=process.execPath;return W.join(W.dirname(e),z.NPM_TOOL)},j.executeCommand=function(e,t,n){0!==(0,U.spawnSync)(e,t,n).status&&(0,K.logErrorAndExit)(`Error: ${e} ${t} execute failed.See above for details.`)},j.offlinePluginConversion=function(e,t){return t.startsWith("file:")||t.endsWith(".tgz")?W.resolve(e,z.HVIGOR,t.replace("file:","")):t},j.isFileExists=function(e){return q.default.existsSync(e)&&q.default.statSync(e).isFile()},function(e){var t=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),n=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),r=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var r={};if(null!=e)for(var u in e)"default"!==u&&Object.prototype.hasOwnProperty.call(e,u)&&t(r,e,u);return n(r,e),r},u=w&&w.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(e,"__esModule",{value:!0}),e.executeInstallPnpm=e.isPnpmAvailable=e.environmentHandler=e.checkNpmConifg=e.PNPM_VERSION=void 0;const o=r(D.default),i=b,s=j,c=r(p.default),a=$,l=h.default,f=u(E.default);e.PNPM_VERSION="7.30.0",e.checkNpmConifg=function(){const e=c.resolve(i.HVIGOR_PROJECT_ROOT_DIR,".npmrc"),t=c.resolve(f.default.homedir(),".npmrc");if((0,s.isFileExists)(e)||(0,s.isFileExists)(t))return;const n=(0,s.getNpmPath)(),r=(0,l.spawnSync)(n,["config","get","prefix"],{cwd:i.HVIGOR_PROJECT_ROOT_DIR});if(0!==r.status||!r.stdout)return void(0,a.logErrorAndExit)("Error: The hvigor depends on the npmrc file. Configure the npmrc file first.");const u=c.resolve(`${r.stdout}`.replace(/[\r\n]/gi,""),".npmrc");(0,s.isFileExists)(u)||(0,a.logErrorAndExit)("Error: The hvigor depends on the npmrc file. Configure the npmrc file first.")},e.environmentHandler=function(){process.env["npm_config_update-notifier"]="false"},e.isPnpmAvailable=function(){return!!o.existsSync(i.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH)&&(0,s.hasNpmPackInPaths)("pnpm",[i.HVIGOR_WRAPPER_TOOLS_HOME])},e.executeInstallPnpm=function(){(0,a.logInfoPrintConsole)(`Installing pnpm@${e.PNPM_VERSION}...`);const t=(0,s.getNpmPath)();!function(){const t=c.resolve(i.HVIGOR_WRAPPER_TOOLS_HOME,i.DEFAULT_PACKAGE_JSON);try{o.existsSync(i.HVIGOR_WRAPPER_TOOLS_HOME)||o.mkdirSync(i.HVIGOR_WRAPPER_TOOLS_HOME,{recursive:!0});const n={dependencies:{}};n.dependencies[i.PNPM]=e.PNPM_VERSION,o.writeFileSync(t,JSON.stringify(n))}catch(e){(0,a.logErrorAndExit)(`Error: EPERM: operation not permitted,create ${t} failed.`)}}(),(0,s.executeCommand)(t,["install","pnpm"],{cwd:i.HVIGOR_WRAPPER_TOOLS_HOME,stdio:["inherit","inherit","inherit"],env:process.env}),(0,a.logInfoPrintConsole)("Pnpm install success.")}}(O);var Y={},X={},Z={},Q={};Object.defineProperty(Q,"__esModule",{value:!0}),Q.Unicode=void 0;class ee{}Q.Unicode=ee,ee.Space_Separator=/[\u1680\u2000-\u200A\u202F\u205F\u3000]/,ee.ID_Start=/[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u05D0-\u05EA\u05F0-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u0860-\u086A\u08A0-\u08B4\u08B6-\u08BD\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u09FC\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0AF9\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58-\u0C5A\u0C60\u0C61\u0C80\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D54-\u0D56\u0D5F-\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1711\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1877\u1880-\u1884\u1887-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1C80-\u1C88\u1CE9-\u1CEC\u1CEE-\u1CF1\u1CF5\u1CF6\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005-\u3007\u3021-\u3029\u3031-\u3035\u3038-\u303C\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312E\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FEA\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6EF\uA717-\uA71F\uA722-\uA788\uA78B-\uA7AE\uA7B0-\uA7B7\uA7F7-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA8FD\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uA9E0-\uA9E4\uA9E6-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB65\uAB70-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD40-\uDD74\uDE80-\uDE9C\uDEA0-\uDED0\uDF00-\uDF1F\uDF2D-\uDF4A\uDF50-\uDF75\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDCB0-\uDCD3\uDCD8-\uDCFB\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDCE0-\uDCF2\uDCF4\uDCF5\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00\uDE10-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE4\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48\uDC80-\uDCB2\uDCC0-\uDCF2]|\uD804[\uDC03-\uDC37\uDC83-\uDCAF\uDCD0-\uDCE8\uDD03-\uDD26\uDD50-\uDD72\uDD76\uDD83-\uDDB2\uDDC1-\uDDC4\uDDDA\uDDDC\uDE00-\uDE11\uDE13-\uDE2B\uDE80-\uDE86\uDE88\uDE8A-\uDE8D\uDE8F-\uDE9D\uDE9F-\uDEA8\uDEB0-\uDEDE\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3D\uDF50\uDF5D-\uDF61]|\uD805[\uDC00-\uDC34\uDC47-\uDC4A\uDC80-\uDCAF\uDCC4\uDCC5\uDCC7\uDD80-\uDDAE\uDDD8-\uDDDB\uDE00-\uDE2F\uDE44\uDE80-\uDEAA\uDF00-\uDF19]|\uD806[\uDCA0-\uDCDF\uDCFF\uDE00\uDE0B-\uDE32\uDE3A\uDE50\uDE5C-\uDE83\uDE86-\uDE89\uDEC0-\uDEF8]|\uD807[\uDC00-\uDC08\uDC0A-\uDC2E\uDC40\uDC72-\uDC8F\uDD00-\uDD06\uDD08\uDD09\uDD0B-\uDD30\uDD46]|\uD808[\uDC00-\uDF99]|\uD809[\uDC00-\uDC6E\uDC80-\uDD43]|[\uD80C\uD81C-\uD820\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD811[\uDC00-\uDE46]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDED0-\uDEED\uDF00-\uDF2F\uDF40-\uDF43\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50\uDF93-\uDF9F\uDFE0\uDFE1]|\uD821[\uDC00-\uDFEC]|\uD822[\uDC00-\uDEF2]|\uD82C[\uDC00-\uDD1E\uDD70-\uDEFB]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB]|\uD83A[\uDC00-\uDCC4\uDD00-\uDD43]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0]|\uD87E[\uDC00-\uDE1D]/,ee.ID_Continue=/[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0300-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u0483-\u0487\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u0591-\u05BD\u05BF\u05C1\u05C2\u05C4\u05C5\u05C7\u05D0-\u05EA\u05F0-\u05F2\u0610-\u061A\u0620-\u0669\u066E-\u06D3\u06D5-\u06DC\u06DF-\u06E8\u06EA-\u06FC\u06FF\u0710-\u074A\u074D-\u07B1\u07C0-\u07F5\u07FA\u0800-\u082D\u0840-\u085B\u0860-\u086A\u08A0-\u08B4\u08B6-\u08BD\u08D4-\u08E1\u08E3-\u0963\u0966-\u096F\u0971-\u0983\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BC-\u09C4\u09C7\u09C8\u09CB-\u09CE\u09D7\u09DC\u09DD\u09DF-\u09E3\u09E6-\u09F1\u09FC\u0A01-\u0A03\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A3C\u0A3E-\u0A42\u0A47\u0A48\u0A4B-\u0A4D\u0A51\u0A59-\u0A5C\u0A5E\u0A66-\u0A75\u0A81-\u0A83\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABC-\u0AC5\u0AC7-\u0AC9\u0ACB-\u0ACD\u0AD0\u0AE0-\u0AE3\u0AE6-\u0AEF\u0AF9-\u0AFF\u0B01-\u0B03\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3C-\u0B44\u0B47\u0B48\u0B4B-\u0B4D\u0B56\u0B57\u0B5C\u0B5D\u0B5F-\u0B63\u0B66-\u0B6F\u0B71\u0B82\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BBE-\u0BC2\u0BC6-\u0BC8\u0BCA-\u0BCD\u0BD0\u0BD7\u0BE6-\u0BEF\u0C00-\u0C03\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D-\u0C44\u0C46-\u0C48\u0C4A-\u0C4D\u0C55\u0C56\u0C58-\u0C5A\u0C60-\u0C63\u0C66-\u0C6F\u0C80-\u0C83\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBC-\u0CC4\u0CC6-\u0CC8\u0CCA-\u0CCD\u0CD5\u0CD6\u0CDE\u0CE0-\u0CE3\u0CE6-\u0CEF\u0CF1\u0CF2\u0D00-\u0D03\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D44\u0D46-\u0D48\u0D4A-\u0D4E\u0D54-\u0D57\u0D5F-\u0D63\u0D66-\u0D6F\u0D7A-\u0D7F\u0D82\u0D83\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0DCA\u0DCF-\u0DD4\u0DD6\u0DD8-\u0DDF\u0DE6-\u0DEF\u0DF2\u0DF3\u0E01-\u0E3A\u0E40-\u0E4E\u0E50-\u0E59\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB9\u0EBB-\u0EBD\u0EC0-\u0EC4\u0EC6\u0EC8-\u0ECD\u0ED0-\u0ED9\u0EDC-\u0EDF\u0F00\u0F18\u0F19\u0F20-\u0F29\u0F35\u0F37\u0F39\u0F3E-\u0F47\u0F49-\u0F6C\u0F71-\u0F84\u0F86-\u0F97\u0F99-\u0FBC\u0FC6\u1000-\u1049\u1050-\u109D\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u135D-\u135F\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1714\u1720-\u1734\u1740-\u1753\u1760-\u176C\u176E-\u1770\u1772\u1773\u1780-\u17D3\u17D7\u17DC\u17DD\u17E0-\u17E9\u180B-\u180D\u1810-\u1819\u1820-\u1877\u1880-\u18AA\u18B0-\u18F5\u1900-\u191E\u1920-\u192B\u1930-\u193B\u1946-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u19D0-\u19D9\u1A00-\u1A1B\u1A20-\u1A5E\u1A60-\u1A7C\u1A7F-\u1A89\u1A90-\u1A99\u1AA7\u1AB0-\u1ABD\u1B00-\u1B4B\u1B50-\u1B59\u1B6B-\u1B73\u1B80-\u1BF3\u1C00-\u1C37\u1C40-\u1C49\u1C4D-\u1C7D\u1C80-\u1C88\u1CD0-\u1CD2\u1CD4-\u1CF9\u1D00-\u1DF9\u1DFB-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u203F\u2040\u2054\u2071\u207F\u2090-\u209C\u20D0-\u20DC\u20E1\u20E5-\u20F0\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D7F-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2DE0-\u2DFF\u2E2F\u3005-\u3007\u3021-\u302F\u3031-\u3035\u3038-\u303C\u3041-\u3096\u3099\u309A\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312E\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FEA\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA62B\uA640-\uA66F\uA674-\uA67D\uA67F-\uA6F1\uA717-\uA71F\uA722-\uA788\uA78B-\uA7AE\uA7B0-\uA7B7\uA7F7-\uA827\uA840-\uA873\uA880-\uA8C5\uA8D0-\uA8D9\uA8E0-\uA8F7\uA8FB\uA8FD\uA900-\uA92D\uA930-\uA953\uA960-\uA97C\uA980-\uA9C0\uA9CF-\uA9D9\uA9E0-\uA9FE\uAA00-\uAA36\uAA40-\uAA4D\uAA50-\uAA59\uAA60-\uAA76\uAA7A-\uAAC2\uAADB-\uAADD\uAAE0-\uAAEF\uAAF2-\uAAF6\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB65\uAB70-\uABEA\uABEC\uABED\uABF0-\uABF9\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE00-\uFE0F\uFE20-\uFE2F\uFE33\uFE34\uFE4D-\uFE4F\uFE70-\uFE74\uFE76-\uFEFC\uFF10-\uFF19\uFF21-\uFF3A\uFF3F\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD40-\uDD74\uDDFD\uDE80-\uDE9C\uDEA0-\uDED0\uDEE0\uDF00-\uDF1F\uDF2D-\uDF4A\uDF50-\uDF7A\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDCA0-\uDCA9\uDCB0-\uDCD3\uDCD8-\uDCFB\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDCE0-\uDCF2\uDCF4\uDCF5\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00-\uDE03\uDE05\uDE06\uDE0C-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE38-\uDE3A\uDE3F\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE6\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48\uDC80-\uDCB2\uDCC0-\uDCF2]|\uD804[\uDC00-\uDC46\uDC66-\uDC6F\uDC7F-\uDCBA\uDCD0-\uDCE8\uDCF0-\uDCF9\uDD00-\uDD34\uDD36-\uDD3F\uDD50-\uDD73\uDD76\uDD80-\uDDC4\uDDCA-\uDDCC\uDDD0-\uDDDA\uDDDC\uDE00-\uDE11\uDE13-\uDE37\uDE3E\uDE80-\uDE86\uDE88\uDE8A-\uDE8D\uDE8F-\uDE9D\uDE9F-\uDEA8\uDEB0-\uDEEA\uDEF0-\uDEF9\uDF00-\uDF03\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3C-\uDF44\uDF47\uDF48\uDF4B-\uDF4D\uDF50\uDF57\uDF5D-\uDF63\uDF66-\uDF6C\uDF70-\uDF74]|\uD805[\uDC00-\uDC4A\uDC50-\uDC59\uDC80-\uDCC5\uDCC7\uDCD0-\uDCD9\uDD80-\uDDB5\uDDB8-\uDDC0\uDDD8-\uDDDD\uDE00-\uDE40\uDE44\uDE50-\uDE59\uDE80-\uDEB7\uDEC0-\uDEC9\uDF00-\uDF19\uDF1D-\uDF2B\uDF30-\uDF39]|\uD806[\uDCA0-\uDCE9\uDCFF\uDE00-\uDE3E\uDE47\uDE50-\uDE83\uDE86-\uDE99\uDEC0-\uDEF8]|\uD807[\uDC00-\uDC08\uDC0A-\uDC36\uDC38-\uDC40\uDC50-\uDC59\uDC72-\uDC8F\uDC92-\uDCA7\uDCA9-\uDCB6\uDD00-\uDD06\uDD08\uDD09\uDD0B-\uDD36\uDD3A\uDD3C\uDD3D\uDD3F-\uDD47\uDD50-\uDD59]|\uD808[\uDC00-\uDF99]|\uD809[\uDC00-\uDC6E\uDC80-\uDD43]|[\uD80C\uD81C-\uD820\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD811[\uDC00-\uDE46]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDE60-\uDE69\uDED0-\uDEED\uDEF0-\uDEF4\uDF00-\uDF36\uDF40-\uDF43\uDF50-\uDF59\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50-\uDF7E\uDF8F-\uDF9F\uDFE0\uDFE1]|\uD821[\uDC00-\uDFEC]|\uD822[\uDC00-\uDEF2]|\uD82C[\uDC00-\uDD1E\uDD70-\uDEFB]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99\uDC9D\uDC9E]|\uD834[\uDD65-\uDD69\uDD6D-\uDD72\uDD7B-\uDD82\uDD85-\uDD8B\uDDAA-\uDDAD\uDE42-\uDE44]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB\uDFCE-\uDFFF]|\uD836[\uDE00-\uDE36\uDE3B-\uDE6C\uDE75\uDE84\uDE9B-\uDE9F\uDEA1-\uDEAF]|\uD838[\uDC00-\uDC06\uDC08-\uDC18\uDC1B-\uDC21\uDC23\uDC24\uDC26-\uDC2A]|\uD83A[\uDC00-\uDCC4\uDCD0-\uDCD6\uDD00-\uDD4A\uDD50-\uDD59]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0]|\uD87E[\uDC00-\uDE1D]|\uDB40[\uDD00-\uDDEF]/,Object.defineProperty(Z,"__esModule",{value:!0}),Z.JudgeUtil=void 0;const te=Q;Z.JudgeUtil=class{static isIgnoreChar(e){return"string"==typeof e&&("\t"===e||"\v"===e||"\f"===e||" "===e||" "===e||"\ufeff"===e||"\n"===e||"\r"===e||"\u2028"===e||"\u2029"===e)}static isSpaceSeparator(e){return"string"==typeof e&&te.Unicode.Space_Separator.test(e)}static isIdStartChar(e){return"string"==typeof e&&(e>="a"&&e<="z"||e>="A"&&e<="Z"||"$"===e||"_"===e||te.Unicode.ID_Start.test(e))}static isIdContinueChar(e){return"string"==typeof e&&(e>="a"&&e<="z"||e>="A"&&e<="Z"||e>="0"&&e<="9"||"$"===e||"_"===e||""===e||""===e||te.Unicode.ID_Continue.test(e))}static isDigitWithoutZero(e){return/[1-9]/.test(e)}static isDigit(e){return"string"==typeof e&&/[0-9]/.test(e)}static isHexDigit(e){return"string"==typeof e&&/[0-9A-Fa-f]/.test(e)}};var ne={},re={fromCallback:function(e){return Object.defineProperty((function(...t){if("function"!=typeof t[t.length-1])return new Promise(((n,r)=>{e.call(this,...t,((e,t)=>null!=e?r(e):n(t)))}));e.apply(this,t)}),"name",{value:e.name})},fromPromise:function(e){return Object.defineProperty((function(...t){const n=t[t.length-1];if("function"!=typeof n)return e.apply(this,t);e.apply(this,t.slice(0,-1)).then((e=>n(null,e)),n)}),"name",{value:e.name})}},ue=y.default,oe=process.cwd,ie=null,se=process.env.GRACEFUL_FS_PLATFORM||process.platform;process.cwd=function(){return ie||(ie=oe.call(process)),ie};try{process.cwd()}catch(e){}if("function"==typeof process.chdir){var ce=process.chdir;process.chdir=function(e){ie=null,ce.call(process,e)},Object.setPrototypeOf&&Object.setPrototypeOf(process.chdir,ce)}var ae=function(e){ue.hasOwnProperty("O_SYMLINK")&&process.version.match(/^v0\.6\.[0-2]|^v0\.5\./)&&function(e){e.lchmod=function(t,n,r){e.open(t,ue.O_WRONLY|ue.O_SYMLINK,n,(function(t,u){t?r&&r(t):e.fchmod(u,n,(function(t){e.close(u,(function(e){r&&r(t||e)}))}))}))},e.lchmodSync=function(t,n){var r,u=e.openSync(t,ue.O_WRONLY|ue.O_SYMLINK,n),o=!0;try{r=e.fchmodSync(u,n),o=!1}finally{if(o)try{e.closeSync(u)}catch(e){}else e.closeSync(u)}return r}}(e);e.lutimes||function(e){ue.hasOwnProperty("O_SYMLINK")&&e.futimes?(e.lutimes=function(t,n,r,u){e.open(t,ue.O_SYMLINK,(function(t,o){t?u&&u(t):e.futimes(o,n,r,(function(t){e.close(o,(function(e){u&&u(t||e)}))}))}))},e.lutimesSync=function(t,n,r){var u,o=e.openSync(t,ue.O_SYMLINK),i=!0;try{u=e.futimesSync(o,n,r),i=!1}finally{if(i)try{e.closeSync(o)}catch(e){}else e.closeSync(o)}return u}):e.futimes&&(e.lutimes=function(e,t,n,r){r&&process.nextTick(r)},e.lutimesSync=function(){})}(e);e.chown=r(e.chown),e.fchown=r(e.fchown),e.lchown=r(e.lchown),e.chmod=t(e.chmod),e.fchmod=t(e.fchmod),e.lchmod=t(e.lchmod),e.chownSync=u(e.chownSync),e.fchownSync=u(e.fchownSync),e.lchownSync=u(e.lchownSync),e.chmodSync=n(e.chmodSync),e.fchmodSync=n(e.fchmodSync),e.lchmodSync=n(e.lchmodSync),e.stat=o(e.stat),e.fstat=o(e.fstat),e.lstat=o(e.lstat),e.statSync=i(e.statSync),e.fstatSync=i(e.fstatSync),e.lstatSync=i(e.lstatSync),e.chmod&&!e.lchmod&&(e.lchmod=function(e,t,n){n&&process.nextTick(n)},e.lchmodSync=function(){});e.chown&&!e.lchown&&(e.lchown=function(e,t,n,r){r&&process.nextTick(r)},e.lchownSync=function(){});"win32"===se&&(e.rename="function"!=typeof e.rename?e.rename:function(t){function n(n,r,u){var o=Date.now(),i=0;t(n,r,(function s(c){if(c&&("EACCES"===c.code||"EPERM"===c.code||"EBUSY"===c.code)&&Date.now()-o<6e4)return setTimeout((function(){e.stat(r,(function(e,o){e&&"ENOENT"===e.code?t(n,r,s):u(c)}))}),i),void(i<100&&(i+=10));u&&u(c)}))}return Object.setPrototypeOf&&Object.setPrototypeOf(n,t),n}(e.rename));function t(t){return t?function(n,r,u){return t.call(e,n,r,(function(e){s(e)&&(e=null),u&&u.apply(this,arguments)}))}:t}function n(t){return t?function(n,r){try{return t.call(e,n,r)}catch(e){if(!s(e))throw e}}:t}function r(t){return t?function(n,r,u,o){return t.call(e,n,r,u,(function(e){s(e)&&(e=null),o&&o.apply(this,arguments)}))}:t}function u(t){return t?function(n,r,u){try{return t.call(e,n,r,u)}catch(e){if(!s(e))throw e}}:t}function o(t){return t?function(n,r,u){function o(e,t){t&&(t.uid<0&&(t.uid+=4294967296),t.gid<0&&(t.gid+=4294967296)),u&&u.apply(this,arguments)}return"function"==typeof r&&(u=r,r=null),r?t.call(e,n,r,o):t.call(e,n,o)}:t}function i(t){return t?function(n,r){var u=r?t.call(e,n,r):t.call(e,n);return u&&(u.uid<0&&(u.uid+=4294967296),u.gid<0&&(u.gid+=4294967296)),u}:t}function s(e){return!e||("ENOSYS"===e.code||!(process.getuid&&0===process.getuid()||"EINVAL"!==e.code&&"EPERM"!==e.code))}e.read="function"!=typeof e.read?e.read:function(t){function n(n,r,u,o,i,s){var c;if(s&&"function"==typeof s){var a=0;c=function(l,f,d){if(l&&"EAGAIN"===l.code&&a<10)return a++,t.call(e,n,r,u,o,i,c);s.apply(this,arguments)}}return t.call(e,n,r,u,o,i,c)}return Object.setPrototypeOf&&Object.setPrototypeOf(n,t),n}(e.read),e.readSync="function"!=typeof e.readSync?e.readSync:(c=e.readSync,function(t,n,r,u,o){for(var i=0;;)try{return c.call(e,t,n,r,u,o)}catch(e){if("EAGAIN"===e.code&&i<10){i++;continue}throw e}});var c};var le=C.default.Stream,fe=function(e){return{ReadStream:function t(n,r){if(!(this instanceof t))return new t(n,r);le.call(this);var u=this;this.path=n,this.fd=null,this.readable=!0,this.paused=!1,this.flags="r",this.mode=438,this.bufferSize=65536,r=r||{};for(var o=Object.keys(r),i=0,s=o.length;ithis.end)throw new Error("start must be <= end");this.pos=this.start}if(null!==this.fd)return void process.nextTick((function(){u._read()}));e.open(this.path,this.flags,this.mode,(function(e,t){if(e)return u.emit("error",e),void(u.readable=!1);u.fd=t,u.emit("open",t),u._read()}))},WriteStream:function t(n,r){if(!(this instanceof t))return new t(n,r);le.call(this),this.path=n,this.fd=null,this.writable=!0,this.flags="w",this.encoding="binary",this.mode=438,this.bytesWritten=0,r=r||{};for(var u=Object.keys(r),o=0,i=u.length;o= zero");this.pos=this.start}this.busy=!1,this._queue=[],null===this.fd&&(this._open=e.open,this._queue.push([this._open,this.path,this.flags,this.mode,void 0]),this.flush())}}};var de=function(e){if(null===e||"object"!=typeof e)return e;if(e instanceof Object)var t={__proto__:De(e)};else t=Object.create(null);return Object.getOwnPropertyNames(e).forEach((function(n){Object.defineProperty(t,n,Object.getOwnPropertyDescriptor(e,n))})),t},De=Object.getPrototypeOf||function(e){return e.__proto__};var pe,Ee,me=D.default,he=ae,ye=fe,Ce=de,Fe=F.default;function ge(e,t){Object.defineProperty(e,pe,{get:function(){return t}})}"function"==typeof Symbol&&"function"==typeof Symbol.for?(pe=Symbol.for("graceful-fs.queue"),Ee=Symbol.for("graceful-fs.previous")):(pe="___graceful-fs.queue",Ee="___graceful-fs.previous");var Ae=function(){};if(Fe.debuglog?Ae=Fe.debuglog("gfs4"):/\bgfs4\b/i.test(process.env.NODE_DEBUG||"")&&(Ae=function(){var e=Fe.format.apply(Fe,arguments);e="GFS4: "+e.split(/\n/).join("\nGFS4: "),console.error(e)}),!me[pe]){var ve=w[pe]||[];ge(me,ve),me.close=function(e){function t(t,n){return e.call(me,t,(function(e){e||_e(),"function"==typeof n&&n.apply(this,arguments)}))}return Object.defineProperty(t,Ee,{value:e}),t}(me.close),me.closeSync=function(e){function t(t){e.apply(me,arguments),_e()}return Object.defineProperty(t,Ee,{value:e}),t}(me.closeSync),/\bgfs4\b/i.test(process.env.NODE_DEBUG||"")&&process.on("exit",(function(){Ae(me[pe]),g.default.equal(me[pe].length,0)}))}w[pe]||ge(w,me[pe]);var Se,we=Oe(Ce(me));function Oe(e){he(e),e.gracefulify=Oe,e.createReadStream=function(t,n){return new e.ReadStream(t,n)},e.createWriteStream=function(t,n){return new e.WriteStream(t,n)};var t=e.readFile;e.readFile=function(e,n,r){"function"==typeof n&&(r=n,n=null);return function e(n,r,u,o){return t(n,r,(function(t){!t||"EMFILE"!==t.code&&"ENFILE"!==t.code?"function"==typeof u&&u.apply(this,arguments):be([e,[n,r,u],t,o||Date.now(),Date.now()])}))}(e,n,r)};var n=e.writeFile;e.writeFile=function(e,t,r,u){"function"==typeof r&&(u=r,r=null);return function e(t,r,u,o,i){return n(t,r,u,(function(n){!n||"EMFILE"!==n.code&&"ENFILE"!==n.code?"function"==typeof o&&o.apply(this,arguments):be([e,[t,r,u,o],n,i||Date.now(),Date.now()])}))}(e,t,r,u)};var r=e.appendFile;r&&(e.appendFile=function(e,t,n,u){"function"==typeof n&&(u=n,n=null);return function e(t,n,u,o,i){return r(t,n,u,(function(r){!r||"EMFILE"!==r.code&&"ENFILE"!==r.code?"function"==typeof o&&o.apply(this,arguments):be([e,[t,n,u,o],r,i||Date.now(),Date.now()])}))}(e,t,n,u)});var u=e.copyFile;u&&(e.copyFile=function(e,t,n,r){"function"==typeof n&&(r=n,n=0);return function e(t,n,r,o,i){return u(t,n,r,(function(u){!u||"EMFILE"!==u.code&&"ENFILE"!==u.code?"function"==typeof o&&o.apply(this,arguments):be([e,[t,n,r,o],u,i||Date.now(),Date.now()])}))}(e,t,n,r)});var o=e.readdir;e.readdir=function(e,t,n){"function"==typeof t&&(n=t,t=null);var r=i.test(process.version)?function(e,t,n,r){return o(e,u(e,t,n,r))}:function(e,t,n,r){return o(e,t,u(e,t,n,r))};return r(e,t,n);function u(e,t,n,u){return function(o,i){!o||"EMFILE"!==o.code&&"ENFILE"!==o.code?(i&&i.sort&&i.sort(),"function"==typeof n&&n.call(this,o,i)):be([r,[e,t,n],o,u||Date.now(),Date.now()])}}};var i=/^v[0-5]\./;if("v0.8"===process.version.substr(0,4)){var s=ye(e);d=s.ReadStream,D=s.WriteStream}var c=e.ReadStream;c&&(d.prototype=Object.create(c.prototype),d.prototype.open=function(){var e=this;E(e.path,e.flags,e.mode,(function(t,n){t?(e.autoClose&&e.destroy(),e.emit("error",t)):(e.fd=n,e.emit("open",n),e.read())}))});var a=e.WriteStream;a&&(D.prototype=Object.create(a.prototype),D.prototype.open=function(){var e=this;E(e.path,e.flags,e.mode,(function(t,n){t?(e.destroy(),e.emit("error",t)):(e.fd=n,e.emit("open",n))}))}),Object.defineProperty(e,"ReadStream",{get:function(){return d},set:function(e){d=e},enumerable:!0,configurable:!0}),Object.defineProperty(e,"WriteStream",{get:function(){return D},set:function(e){D=e},enumerable:!0,configurable:!0});var l=d;Object.defineProperty(e,"FileReadStream",{get:function(){return l},set:function(e){l=e},enumerable:!0,configurable:!0});var f=D;function d(e,t){return this instanceof d?(c.apply(this,arguments),this):d.apply(Object.create(d.prototype),arguments)}function D(e,t){return this instanceof D?(a.apply(this,arguments),this):D.apply(Object.create(D.prototype),arguments)}Object.defineProperty(e,"FileWriteStream",{get:function(){return f},set:function(e){f=e},enumerable:!0,configurable:!0});var p=e.open;function E(e,t,n,r){return"function"==typeof n&&(r=n,n=null),function e(t,n,r,u,o){return p(t,n,r,(function(i,s){!i||"EMFILE"!==i.code&&"ENFILE"!==i.code?"function"==typeof u&&u.apply(this,arguments):be([e,[t,n,r,u],i,o||Date.now(),Date.now()])}))}(e,t,n,r)}return e.open=E,e}function be(e){Ae("ENQUEUE",e[0].name,e[1]),me[pe].push(e),Be()}function _e(){for(var e=Date.now(),t=0;t2&&(me[pe][t][3]=e,me[pe][t][4]=e);Be()}function Be(){if(clearTimeout(Se),Se=void 0,0!==me[pe].length){var e=me[pe].shift(),t=e[0],n=e[1],r=e[2],u=e[3],o=e[4];if(void 0===u)Ae("RETRY",t.name,n),t.apply(null,n);else if(Date.now()-u>=6e4){Ae("TIMEOUT",t.name,n);var i=n.pop();"function"==typeof i&&i.call(null,r)}else{var s=Date.now()-o,c=Math.max(o-u,1);s>=Math.min(1.2*c,100)?(Ae("RETRY",t.name,n),t.apply(null,n.concat([u]))):me[pe].push(e)}void 0===Se&&(Se=setTimeout(Be,0))}}process.env.TEST_GRACEFUL_FS_GLOBAL_PATCH&&!me.__patched&&(we=Oe(me),me.__patched=!0),function(e){const t=re.fromCallback,n=we,r=["access","appendFile","chmod","chown","close","copyFile","fchmod","fchown","fdatasync","fstat","fsync","ftruncate","futimes","lchmod","lchown","link","lstat","mkdir","mkdtemp","open","opendir","readdir","readFile","readlink","realpath","rename","rm","rmdir","stat","symlink","truncate","unlink","utimes","writeFile"].filter((e=>"function"==typeof n[e]));Object.assign(e,n),r.forEach((r=>{e[r]=t(n[r])})),e.realpath.native=t(n.realpath.native),e.exists=function(e,t){return"function"==typeof t?n.exists(e,t):new Promise((t=>n.exists(e,t)))},e.read=function(e,t,r,u,o,i){return"function"==typeof i?n.read(e,t,r,u,o,i):new Promise(((i,s)=>{n.read(e,t,r,u,o,((e,t,n)=>{if(e)return s(e);i({bytesRead:t,buffer:n})}))}))},e.write=function(e,t,...r){return"function"==typeof r[r.length-1]?n.write(e,t,...r):new Promise(((u,o)=>{n.write(e,t,...r,((e,t,n)=>{if(e)return o(e);u({bytesWritten:t,buffer:n})}))}))},"function"==typeof n.writev&&(e.writev=function(e,t,...r){return"function"==typeof r[r.length-1]?n.writev(e,t,...r):new Promise(((u,o)=>{n.writev(e,t,...r,((e,t,n)=>{if(e)return o(e);u({bytesWritten:t,buffers:n})}))}))})}(ne);var Pe={},ke={};const xe=p.default;ke.checkPath=function(e){if("win32"===process.platform){if(/[<>:"|?*]/.test(e.replace(xe.parse(e).root,""))){const t=new Error(`Path contains invalid characters: ${e}`);throw t.code="EINVAL",t}}};const Ne=ne,{checkPath:Ie}=ke,Te=e=>"number"==typeof e?e:{mode:511,...e}.mode;Pe.makeDir=async(e,t)=>(Ie(e),Ne.mkdir(e,{mode:Te(t),recursive:!0})),Pe.makeDirSync=(e,t)=>(Ie(e),Ne.mkdirSync(e,{mode:Te(t),recursive:!0}));const Re=re.fromPromise,{makeDir:Me,makeDirSync:Le}=Pe,je=Re(Me);var $e={mkdirs:je,mkdirsSync:Le,mkdirp:je,mkdirpSync:Le,ensureDir:je,ensureDirSync:Le};const He=re.fromPromise,Je=ne;var Ge={pathExists:He((function(e){return Je.access(e).then((()=>!0)).catch((()=>!1))})),pathExistsSync:Je.existsSync};const Ve=we;var Ue=function(e,t,n,r){Ve.open(e,"r+",((e,u)=>{if(e)return r(e);Ve.futimes(u,t,n,(e=>{Ve.close(u,(t=>{r&&r(e||t)}))}))}))},We=function(e,t,n){const r=Ve.openSync(e,"r+");return Ve.futimesSync(r,t,n),Ve.closeSync(r)};const ze=ne,Ke=p.default,qe=F.default;function Ye(e,t,n){const r=n.dereference?e=>ze.stat(e,{bigint:!0}):e=>ze.lstat(e,{bigint:!0});return Promise.all([r(e),r(t).catch((e=>{if("ENOENT"===e.code)return null;throw e}))]).then((([e,t])=>({srcStat:e,destStat:t})))}function Xe(e,t){return t.ino&&t.dev&&t.ino===e.ino&&t.dev===e.dev}function Ze(e,t){const n=Ke.resolve(e).split(Ke.sep).filter((e=>e)),r=Ke.resolve(t).split(Ke.sep).filter((e=>e));return n.reduce(((e,t,n)=>e&&r[n]===t),!0)}function Qe(e,t,n){return`Cannot ${n} '${e}' to a subdirectory of itself, '${t}'.`}var et={checkPaths:function(e,t,n,r,u){qe.callbackify(Ye)(e,t,r,((r,o)=>{if(r)return u(r);const{srcStat:i,destStat:s}=o;if(s){if(Xe(i,s)){const r=Ke.basename(e),o=Ke.basename(t);return"move"===n&&r!==o&&r.toLowerCase()===o.toLowerCase()?u(null,{srcStat:i,destStat:s,isChangingCase:!0}):u(new Error("Source and destination must not be the same."))}if(i.isDirectory()&&!s.isDirectory())return u(new Error(`Cannot overwrite non-directory '${t}' with directory '${e}'.`));if(!i.isDirectory()&&s.isDirectory())return u(new Error(`Cannot overwrite directory '${t}' with non-directory '${e}'.`))}return i.isDirectory()&&Ze(e,t)?u(new Error(Qe(e,t,n))):u(null,{srcStat:i,destStat:s})}))},checkPathsSync:function(e,t,n,r){const{srcStat:u,destStat:o}=function(e,t,n){let r;const u=n.dereference?e=>ze.statSync(e,{bigint:!0}):e=>ze.lstatSync(e,{bigint:!0}),o=u(e);try{r=u(t)}catch(e){if("ENOENT"===e.code)return{srcStat:o,destStat:null};throw e}return{srcStat:o,destStat:r}}(e,t,r);if(o){if(Xe(u,o)){const r=Ke.basename(e),i=Ke.basename(t);if("move"===n&&r!==i&&r.toLowerCase()===i.toLowerCase())return{srcStat:u,destStat:o,isChangingCase:!0};throw new Error("Source and destination must not be the same.")}if(u.isDirectory()&&!o.isDirectory())throw new Error(`Cannot overwrite non-directory '${t}' with directory '${e}'.`);if(!u.isDirectory()&&o.isDirectory())throw new Error(`Cannot overwrite directory '${t}' with non-directory '${e}'.`)}if(u.isDirectory()&&Ze(e,t))throw new Error(Qe(e,t,n));return{srcStat:u,destStat:o}},checkParentPaths:function e(t,n,r,u,o){const i=Ke.resolve(Ke.dirname(t)),s=Ke.resolve(Ke.dirname(r));if(s===i||s===Ke.parse(s).root)return o();ze.stat(s,{bigint:!0},((i,c)=>i?"ENOENT"===i.code?o():o(i):Xe(n,c)?o(new Error(Qe(t,r,u))):e(t,n,s,u,o)))},checkParentPathsSync:function e(t,n,r,u){const o=Ke.resolve(Ke.dirname(t)),i=Ke.resolve(Ke.dirname(r));if(i===o||i===Ke.parse(i).root)return;let s;try{s=ze.statSync(i,{bigint:!0})}catch(e){if("ENOENT"===e.code)return;throw e}if(Xe(n,s))throw new Error(Qe(t,r,u));return e(t,n,i,u)},isSrcSubdir:Ze,areIdentical:Xe};const tt=we,nt=p.default,rt=$e.mkdirs,ut=Ge.pathExists,ot=Ue,it=et;function st(e,t,n,r,u){const o=nt.dirname(n);ut(o,((i,s)=>i?u(i):s?at(e,t,n,r,u):void rt(o,(o=>o?u(o):at(e,t,n,r,u)))))}function ct(e,t,n,r,u,o){Promise.resolve(u.filter(n,r)).then((i=>i?e(t,n,r,u,o):o()),(e=>o(e)))}function at(e,t,n,r,u){(r.dereference?tt.stat:tt.lstat)(t,((o,i)=>o?u(o):i.isDirectory()?function(e,t,n,r,u,o){return t?Dt(n,r,u,o):function(e,t,n,r,u){tt.mkdir(n,(o=>{if(o)return u(o);Dt(t,n,r,(t=>t?u(t):dt(n,e,u)))}))}(e.mode,n,r,u,o)}(i,e,t,n,r,u):i.isFile()||i.isCharacterDevice()||i.isBlockDevice()?function(e,t,n,r,u,o){return t?function(e,t,n,r,u){if(!r.overwrite)return r.errorOnExist?u(new Error(`'${n}' already exists`)):u();tt.unlink(n,(o=>o?u(o):lt(e,t,n,r,u)))}(e,n,r,u,o):lt(e,n,r,u,o)}(i,e,t,n,r,u):i.isSymbolicLink()?function(e,t,n,r,u){tt.readlink(t,((t,o)=>t?u(t):(r.dereference&&(o=nt.resolve(process.cwd(),o)),e?void tt.readlink(n,((t,i)=>t?"EINVAL"===t.code||"UNKNOWN"===t.code?tt.symlink(o,n,u):u(t):(r.dereference&&(i=nt.resolve(process.cwd(),i)),it.isSrcSubdir(o,i)?u(new Error(`Cannot copy '${o}' to a subdirectory of itself, '${i}'.`)):e.isDirectory()&&it.isSrcSubdir(i,o)?u(new Error(`Cannot overwrite '${i}' with '${o}'.`)):function(e,t,n){tt.unlink(t,(r=>r?n(r):tt.symlink(e,t,n)))}(o,n,u)))):tt.symlink(o,n,u))))}(e,t,n,r,u):i.isSocket()?u(new Error(`Cannot copy a socket file: ${t}`)):i.isFIFO()?u(new Error(`Cannot copy a FIFO pipe: ${t}`)):u(new Error(`Unknown file: ${t}`))))}function lt(e,t,n,r,u){tt.copyFile(t,n,(o=>o?u(o):r.preserveTimestamps?function(e,t,n,r){if(function(e){return 0==(128&e)}(e))return function(e,t,n){return dt(e,128|t,n)}(n,e,(u=>u?r(u):ft(e,t,n,r)));return ft(e,t,n,r)}(e.mode,t,n,u):dt(n,e.mode,u)))}function ft(e,t,n,r){!function(e,t,n){tt.stat(e,((e,r)=>e?n(e):ot(t,r.atime,r.mtime,n)))}(t,n,(t=>t?r(t):dt(n,e,r)))}function dt(e,t,n){return tt.chmod(e,t,n)}function Dt(e,t,n,r){tt.readdir(e,((u,o)=>u?r(u):pt(o,e,t,n,r)))}function pt(e,t,n,r,u){const o=e.pop();return o?function(e,t,n,r,u,o){const i=nt.join(n,t),s=nt.join(r,t);it.checkPaths(i,s,"copy",u,((t,c)=>{if(t)return o(t);const{destStat:a}=c;!function(e,t,n,r,u){r.filter?ct(at,e,t,n,r,u):at(e,t,n,r,u)}(a,i,s,u,(t=>t?o(t):pt(e,n,r,u,o)))}))}(e,o,t,n,r,u):u()}var Et=function(e,t,n,r){"function"!=typeof n||r?"function"==typeof n&&(n={filter:n}):(r=n,n={}),r=r||function(){},(n=n||{}).clobber=!("clobber"in n)||!!n.clobber,n.overwrite="overwrite"in n?!!n.overwrite:n.clobber,n.preserveTimestamps&&"ia32"===process.arch&&console.warn("fs-extra: Using the preserveTimestamps option in 32-bit node is not recommended;\n\n see https://github.com/jprichardson/node-fs-extra/issues/269"),it.checkPaths(e,t,"copy",n,((u,o)=>{if(u)return r(u);const{srcStat:i,destStat:s}=o;it.checkParentPaths(e,i,t,"copy",(u=>u?r(u):n.filter?ct(st,s,e,t,n,r):st(s,e,t,n,r)))}))};const mt=we,ht=p.default,yt=$e.mkdirsSync,Ct=We,Ft=et;function gt(e,t,n,r){const u=(r.dereference?mt.statSync:mt.lstatSync)(t);if(u.isDirectory())return function(e,t,n,r,u){return t?St(n,r,u):function(e,t,n,r){return mt.mkdirSync(n),St(t,n,r),vt(n,e)}(e.mode,n,r,u)}(u,e,t,n,r);if(u.isFile()||u.isCharacterDevice()||u.isBlockDevice())return function(e,t,n,r,u){return t?function(e,t,n,r){if(r.overwrite)return mt.unlinkSync(n),At(e,t,n,r);if(r.errorOnExist)throw new Error(`'${n}' already exists`)}(e,n,r,u):At(e,n,r,u)}(u,e,t,n,r);if(u.isSymbolicLink())return function(e,t,n,r){let u=mt.readlinkSync(t);r.dereference&&(u=ht.resolve(process.cwd(),u));if(e){let e;try{e=mt.readlinkSync(n)}catch(e){if("EINVAL"===e.code||"UNKNOWN"===e.code)return mt.symlinkSync(u,n);throw e}if(r.dereference&&(e=ht.resolve(process.cwd(),e)),Ft.isSrcSubdir(u,e))throw new Error(`Cannot copy '${u}' to a subdirectory of itself, '${e}'.`);if(mt.statSync(n).isDirectory()&&Ft.isSrcSubdir(e,u))throw new Error(`Cannot overwrite '${e}' with '${u}'.`);return function(e,t){return mt.unlinkSync(t),mt.symlinkSync(e,t)}(u,n)}return mt.symlinkSync(u,n)}(e,t,n,r);if(u.isSocket())throw new Error(`Cannot copy a socket file: ${t}`);if(u.isFIFO())throw new Error(`Cannot copy a FIFO pipe: ${t}`);throw new Error(`Unknown file: ${t}`)}function At(e,t,n,r){return mt.copyFileSync(t,n),r.preserveTimestamps&&function(e,t,n){(function(e){return 0==(128&e)})(e)&&function(e,t){vt(e,128|t)}(n,e);(function(e,t){const n=mt.statSync(e);Ct(t,n.atime,n.mtime)})(t,n)}(e.mode,t,n),vt(n,e.mode)}function vt(e,t){return mt.chmodSync(e,t)}function St(e,t,n){mt.readdirSync(e).forEach((r=>function(e,t,n,r){const u=ht.join(t,e),o=ht.join(n,e),{destStat:i}=Ft.checkPathsSync(u,o,"copy",r);return function(e,t,n,r){if(!r.filter||r.filter(t,n))return gt(e,t,n,r)}(i,u,o,r)}(r,e,t,n)))}var wt=function(e,t,n){"function"==typeof n&&(n={filter:n}),(n=n||{}).clobber=!("clobber"in n)||!!n.clobber,n.overwrite="overwrite"in n?!!n.overwrite:n.clobber,n.preserveTimestamps&&"ia32"===process.arch&&console.warn("fs-extra: Using the preserveTimestamps option in 32-bit node is not recommended;\n\n see https://github.com/jprichardson/node-fs-extra/issues/269");const{srcStat:r,destStat:u}=Ft.checkPathsSync(e,t,"copy",n);return Ft.checkParentPathsSync(e,r,t,"copy"),function(e,t,n,r){if(r.filter&&!r.filter(t,n))return;const u=ht.dirname(n);mt.existsSync(u)||yt(u);return gt(e,t,n,r)}(u,e,t,n)};var Ot={copy:(0,re.fromCallback)(Et),copySync:wt};const bt=we,_t=p.default,Bt=g.default,Pt="win32"===process.platform;function kt(e){["unlink","chmod","stat","lstat","rmdir","readdir"].forEach((t=>{e[t]=e[t]||bt[t],e[t+="Sync"]=e[t]||bt[t]})),e.maxBusyTries=e.maxBusyTries||3}function xt(e,t,n){let r=0;"function"==typeof t&&(n=t,t={}),Bt(e,"rimraf: missing path"),Bt.strictEqual(typeof e,"string","rimraf: path should be a string"),Bt.strictEqual(typeof n,"function","rimraf: callback function required"),Bt(t,"rimraf: invalid options argument provided"),Bt.strictEqual(typeof t,"object","rimraf: options should be object"),kt(t),Nt(e,t,(function u(o){if(o){if(("EBUSY"===o.code||"ENOTEMPTY"===o.code||"EPERM"===o.code)&&rNt(e,t,u)),100*r)}"ENOENT"===o.code&&(o=null)}n(o)}))}function Nt(e,t,n){Bt(e),Bt(t),Bt("function"==typeof n),t.lstat(e,((r,u)=>r&&"ENOENT"===r.code?n(null):r&&"EPERM"===r.code&&Pt?It(e,t,r,n):u&&u.isDirectory()?Rt(e,t,r,n):void t.unlink(e,(r=>{if(r){if("ENOENT"===r.code)return n(null);if("EPERM"===r.code)return Pt?It(e,t,r,n):Rt(e,t,r,n);if("EISDIR"===r.code)return Rt(e,t,r,n)}return n(r)}))))}function It(e,t,n,r){Bt(e),Bt(t),Bt("function"==typeof r),t.chmod(e,438,(u=>{u?r("ENOENT"===u.code?null:n):t.stat(e,((u,o)=>{u?r("ENOENT"===u.code?null:n):o.isDirectory()?Rt(e,t,n,r):t.unlink(e,r)}))}))}function Tt(e,t,n){let r;Bt(e),Bt(t);try{t.chmodSync(e,438)}catch(e){if("ENOENT"===e.code)return;throw n}try{r=t.statSync(e)}catch(e){if("ENOENT"===e.code)return;throw n}r.isDirectory()?Lt(e,t,n):t.unlinkSync(e)}function Rt(e,t,n,r){Bt(e),Bt(t),Bt("function"==typeof r),t.rmdir(e,(u=>{!u||"ENOTEMPTY"!==u.code&&"EEXIST"!==u.code&&"EPERM"!==u.code?u&&"ENOTDIR"===u.code?r(n):r(u):function(e,t,n){Bt(e),Bt(t),Bt("function"==typeof n),t.readdir(e,((r,u)=>{if(r)return n(r);let o,i=u.length;if(0===i)return t.rmdir(e,n);u.forEach((r=>{xt(_t.join(e,r),t,(r=>{if(!o)return r?n(o=r):void(0==--i&&t.rmdir(e,n))}))}))}))}(e,t,r)}))}function Mt(e,t){let n;kt(t=t||{}),Bt(e,"rimraf: missing path"),Bt.strictEqual(typeof e,"string","rimraf: path should be a string"),Bt(t,"rimraf: missing options"),Bt.strictEqual(typeof t,"object","rimraf: options should be object");try{n=t.lstatSync(e)}catch(n){if("ENOENT"===n.code)return;"EPERM"===n.code&&Pt&&Tt(e,t,n)}try{n&&n.isDirectory()?Lt(e,t,null):t.unlinkSync(e)}catch(n){if("ENOENT"===n.code)return;if("EPERM"===n.code)return Pt?Tt(e,t,n):Lt(e,t,n);if("EISDIR"!==n.code)throw n;Lt(e,t,n)}}function Lt(e,t,n){Bt(e),Bt(t);try{t.rmdirSync(e)}catch(r){if("ENOTDIR"===r.code)throw n;if("ENOTEMPTY"===r.code||"EEXIST"===r.code||"EPERM"===r.code)!function(e,t){if(Bt(e),Bt(t),t.readdirSync(e).forEach((n=>Mt(_t.join(e,n),t))),!Pt){return t.rmdirSync(e,t)}{const n=Date.now();do{try{return t.rmdirSync(e,t)}catch{}}while(Date.now()-n<500)}}(e,t);else if("ENOENT"!==r.code)throw r}}var jt=xt;xt.sync=Mt;const $t=we,Ht=re.fromCallback,Jt=jt;var Gt={remove:Ht((function(e,t){if($t.rm)return $t.rm(e,{recursive:!0,force:!0},t);Jt(e,t)})),removeSync:function(e){if($t.rmSync)return $t.rmSync(e,{recursive:!0,force:!0});Jt.sync(e)}};const Vt=re.fromPromise,Ut=ne,Wt=p.default,zt=$e,Kt=Gt,qt=Vt((async function(e){let t;try{t=await Ut.readdir(e)}catch{return zt.mkdirs(e)}return Promise.all(t.map((t=>Kt.remove(Wt.join(e,t)))))}));function Yt(e){let t;try{t=Ut.readdirSync(e)}catch{return zt.mkdirsSync(e)}t.forEach((t=>{t=Wt.join(e,t),Kt.removeSync(t)}))}var Xt={emptyDirSync:Yt,emptydirSync:Yt,emptyDir:qt,emptydir:qt};const Zt=re.fromCallback,Qt=p.default,en=we,tn=$e;var nn={createFile:Zt((function(e,t){function n(){en.writeFile(e,"",(e=>{if(e)return t(e);t()}))}en.stat(e,((r,u)=>{if(!r&&u.isFile())return t();const o=Qt.dirname(e);en.stat(o,((e,r)=>{if(e)return"ENOENT"===e.code?tn.mkdirs(o,(e=>{if(e)return t(e);n()})):t(e);r.isDirectory()?n():en.readdir(o,(e=>{if(e)return t(e)}))}))}))})),createFileSync:function(e){let t;try{t=en.statSync(e)}catch{}if(t&&t.isFile())return;const n=Qt.dirname(e);try{en.statSync(n).isDirectory()||en.readdirSync(n)}catch(e){if(!e||"ENOENT"!==e.code)throw e;tn.mkdirsSync(n)}en.writeFileSync(e,"")}};const rn=re.fromCallback,un=p.default,on=we,sn=$e,cn=Ge.pathExists,{areIdentical:an}=et;var ln={createLink:rn((function(e,t,n){function r(e,t){on.link(e,t,(e=>{if(e)return n(e);n(null)}))}on.lstat(t,((u,o)=>{on.lstat(e,((u,i)=>{if(u)return u.message=u.message.replace("lstat","ensureLink"),n(u);if(o&&an(i,o))return n(null);const s=un.dirname(t);cn(s,((u,o)=>u?n(u):o?r(e,t):void sn.mkdirs(s,(u=>{if(u)return n(u);r(e,t)}))))}))}))})),createLinkSync:function(e,t){let n;try{n=on.lstatSync(t)}catch{}try{const t=on.lstatSync(e);if(n&&an(t,n))return}catch(e){throw e.message=e.message.replace("lstat","ensureLink"),e}const r=un.dirname(t);return on.existsSync(r)||sn.mkdirsSync(r),on.linkSync(e,t)}};const fn=p.default,dn=we,Dn=Ge.pathExists;var pn={symlinkPaths:function(e,t,n){if(fn.isAbsolute(e))return dn.lstat(e,(t=>t?(t.message=t.message.replace("lstat","ensureSymlink"),n(t)):n(null,{toCwd:e,toDst:e})));{const r=fn.dirname(t),u=fn.join(r,e);return Dn(u,((t,o)=>t?n(t):o?n(null,{toCwd:u,toDst:e}):dn.lstat(e,(t=>t?(t.message=t.message.replace("lstat","ensureSymlink"),n(t)):n(null,{toCwd:e,toDst:fn.relative(r,e)})))))}},symlinkPathsSync:function(e,t){let n;if(fn.isAbsolute(e)){if(n=dn.existsSync(e),!n)throw new Error("absolute srcpath does not exist");return{toCwd:e,toDst:e}}{const r=fn.dirname(t),u=fn.join(r,e);if(n=dn.existsSync(u),n)return{toCwd:u,toDst:e};if(n=dn.existsSync(e),!n)throw new Error("relative srcpath does not exist");return{toCwd:e,toDst:fn.relative(r,e)}}}};const En=we;var mn={symlinkType:function(e,t,n){if(n="function"==typeof t?t:n,t="function"!=typeof t&&t)return n(null,t);En.lstat(e,((e,r)=>{if(e)return n(null,"file");t=r&&r.isDirectory()?"dir":"file",n(null,t)}))},symlinkTypeSync:function(e,t){let n;if(t)return t;try{n=En.lstatSync(e)}catch{return"file"}return n&&n.isDirectory()?"dir":"file"}};const hn=re.fromCallback,yn=p.default,Cn=ne,Fn=$e.mkdirs,gn=$e.mkdirsSync,An=pn.symlinkPaths,vn=pn.symlinkPathsSync,Sn=mn.symlinkType,wn=mn.symlinkTypeSync,On=Ge.pathExists,{areIdentical:bn}=et;function _n(e,t,n,r){An(e,t,((u,o)=>{if(u)return r(u);e=o.toDst,Sn(o.toCwd,n,((n,u)=>{if(n)return r(n);const o=yn.dirname(t);On(o,((n,i)=>n?r(n):i?Cn.symlink(e,t,u,r):void Fn(o,(n=>{if(n)return r(n);Cn.symlink(e,t,u,r)}))))}))}))}var Bn={createSymlink:hn((function(e,t,n,r){r="function"==typeof n?n:r,n="function"!=typeof n&&n,Cn.lstat(t,((u,o)=>{!u&&o.isSymbolicLink()?Promise.all([Cn.stat(e),Cn.stat(t)]).then((([u,o])=>{if(bn(u,o))return r(null);_n(e,t,n,r)})):_n(e,t,n,r)}))})),createSymlinkSync:function(e,t,n){let r;try{r=Cn.lstatSync(t)}catch{}if(r&&r.isSymbolicLink()){const n=Cn.statSync(e),r=Cn.statSync(t);if(bn(n,r))return}const u=vn(e,t);e=u.toDst,n=wn(u.toCwd,n);const o=yn.dirname(t);return Cn.existsSync(o)||gn(o),Cn.symlinkSync(e,t,n)}};const{createFile:Pn,createFileSync:kn}=nn,{createLink:xn,createLinkSync:Nn}=ln,{createSymlink:In,createSymlinkSync:Tn}=Bn;var Rn={createFile:Pn,createFileSync:kn,ensureFile:Pn,ensureFileSync:kn,createLink:xn,createLinkSync:Nn,ensureLink:xn,ensureLinkSync:Nn,createSymlink:In,createSymlinkSync:Tn,ensureSymlink:In,ensureSymlinkSync:Tn};var Mn={stringify:function(e,{EOL:t="\n",finalEOL:n=!0,replacer:r=null,spaces:u}={}){const o=n?t:"";return JSON.stringify(e,r,u).replace(/\n/g,t)+o},stripBom:function(e){return Buffer.isBuffer(e)&&(e=e.toString("utf8")),e.replace(/^\uFEFF/,"")}};let Ln;try{Ln=we}catch(e){Ln=D.default}const jn=re,{stringify:$n,stripBom:Hn}=Mn;const Jn=jn.fromPromise((async function(e,t={}){"string"==typeof t&&(t={encoding:t});const n=t.fs||Ln,r=!("throws"in t)||t.throws;let u,o=await jn.fromCallback(n.readFile)(e,t);o=Hn(o);try{u=JSON.parse(o,t?t.reviver:null)}catch(t){if(r)throw t.message=`${e}: ${t.message}`,t;return null}return u}));const Gn=jn.fromPromise((async function(e,t,n={}){const r=n.fs||Ln,u=$n(t,n);await jn.fromCallback(r.writeFile)(e,u,n)}));const Vn={readFile:Jn,readFileSync:function(e,t={}){"string"==typeof t&&(t={encoding:t});const n=t.fs||Ln,r=!("throws"in t)||t.throws;try{let r=n.readFileSync(e,t);return r=Hn(r),JSON.parse(r,t.reviver)}catch(t){if(r)throw t.message=`${e}: ${t.message}`,t;return null}},writeFile:Gn,writeFileSync:function(e,t,n={}){const r=n.fs||Ln,u=$n(t,n);return r.writeFileSync(e,u,n)}};var Un={readJson:Vn.readFile,readJsonSync:Vn.readFileSync,writeJson:Vn.writeFile,writeJsonSync:Vn.writeFileSync};const Wn=re.fromCallback,zn=we,Kn=p.default,qn=$e,Yn=Ge.pathExists;var Xn={outputFile:Wn((function(e,t,n,r){"function"==typeof n&&(r=n,n="utf8");const u=Kn.dirname(e);Yn(u,((o,i)=>o?r(o):i?zn.writeFile(e,t,n,r):void qn.mkdirs(u,(u=>{if(u)return r(u);zn.writeFile(e,t,n,r)}))))})),outputFileSync:function(e,...t){const n=Kn.dirname(e);if(zn.existsSync(n))return zn.writeFileSync(e,...t);qn.mkdirsSync(n),zn.writeFileSync(e,...t)}};const{stringify:Zn}=Mn,{outputFile:Qn}=Xn;var er=async function(e,t,n={}){const r=Zn(t,n);await Qn(e,r,n)};const{stringify:tr}=Mn,{outputFileSync:nr}=Xn;var rr=function(e,t,n){const r=tr(t,n);nr(e,r,n)};const ur=re.fromPromise,or=Un;or.outputJson=ur(er),or.outputJsonSync=rr,or.outputJSON=or.outputJson,or.outputJSONSync=or.outputJsonSync,or.writeJSON=or.writeJson,or.writeJSONSync=or.writeJsonSync,or.readJSON=or.readJson,or.readJSONSync=or.readJsonSync;var ir=or;const sr=we,cr=p.default,ar=Ot.copy,lr=Gt.remove,fr=$e.mkdirp,dr=Ge.pathExists,Dr=et;function pr(e,t,n,r,u){return r?Er(e,t,n,u):n?lr(t,(r=>r?u(r):Er(e,t,n,u))):void dr(t,((r,o)=>r?u(r):o?u(new Error("dest already exists.")):Er(e,t,n,u)))}function Er(e,t,n,r){sr.rename(e,t,(u=>u?"EXDEV"!==u.code?r(u):function(e,t,n,r){const u={overwrite:n,errorOnExist:!0};ar(e,t,u,(t=>t?r(t):lr(e,r)))}(e,t,n,r):r()))}var mr=function(e,t,n,r){"function"==typeof n&&(r=n,n={});const u=n.overwrite||n.clobber||!1;Dr.checkPaths(e,t,"move",n,((n,o)=>{if(n)return r(n);const{srcStat:i,isChangingCase:s=!1}=o;Dr.checkParentPaths(e,i,t,"move",(n=>n?r(n):function(e){const t=cr.dirname(e);return cr.parse(t).root===t}(t)?pr(e,t,u,s,r):void fr(cr.dirname(t),(n=>n?r(n):pr(e,t,u,s,r)))))}))};const hr=we,yr=p.default,Cr=Ot.copySync,Fr=Gt.removeSync,gr=$e.mkdirpSync,Ar=et;function vr(e,t,n){try{hr.renameSync(e,t)}catch(r){if("EXDEV"!==r.code)throw r;return function(e,t,n){const r={overwrite:n,errorOnExist:!0};return Cr(e,t,r),Fr(e)}(e,t,n)}}var Sr=function(e,t,n){const r=(n=n||{}).overwrite||n.clobber||!1,{srcStat:u,isChangingCase:o=!1}=Ar.checkPathsSync(e,t,"move",n);return Ar.checkParentPathsSync(e,u,t,"move"),function(e){const t=yr.dirname(e);return yr.parse(t).root===t}(t)||gr(yr.dirname(t)),function(e,t,n,r){if(r)return vr(e,t,n);if(n)return Fr(t),vr(e,t,n);if(hr.existsSync(t))throw new Error("dest already exists.");return vr(e,t,n)}(e,t,r,o)};var wr,Or,br,_r,Br,Pr={move:(0,re.fromCallback)(mr),moveSync:Sr},kr={...ne,...Ot,...Xt,...Rn,...ir,...$e,...Pr,...Xn,...Ge,...Gt},xr={},Nr={exports:{}},Ir={exports:{}};function Tr(){if(Or)return wr;Or=1;var e=1e3,t=60*e,n=60*t,r=24*n,u=7*r,o=365.25*r;function i(e,t,n,r){var u=t>=1.5*n;return Math.round(e/n)+" "+r+(u?"s":"")}return wr=function(s,c){c=c||{};var a=typeof s;if("string"===a&&s.length>0)return function(i){if((i=String(i)).length>100)return;var s=/^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(i);if(!s)return;var c=parseFloat(s[1]);switch((s[2]||"ms").toLowerCase()){case"years":case"year":case"yrs":case"yr":case"y":return c*o;case"weeks":case"week":case"w":return c*u;case"days":case"day":case"d":return c*r;case"hours":case"hour":case"hrs":case"hr":case"h":return c*n;case"minutes":case"minute":case"mins":case"min":case"m":return c*t;case"seconds":case"second":case"secs":case"sec":case"s":return c*e;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return c;default:return}}(s);if("number"===a&&isFinite(s))return c.long?function(u){var o=Math.abs(u);if(o>=r)return i(u,o,r,"day");if(o>=n)return i(u,o,n,"hour");if(o>=t)return i(u,o,t,"minute");if(o>=e)return i(u,o,e,"second");return u+" ms"}(s):function(u){var o=Math.abs(u);if(o>=r)return Math.round(u/r)+"d";if(o>=n)return Math.round(u/n)+"h";if(o>=t)return Math.round(u/t)+"m";if(o>=e)return Math.round(u/e)+"s";return u+"ms"}(s);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(s))}}function Rr(){if(_r)return br;return _r=1,br=function(e){function t(e){let r,u,o,i=null;function s(...e){if(!s.enabled)return;const n=s,u=Number(new Date),o=u-(r||u);n.diff=o,n.prev=r,n.curr=u,r=u,e[0]=t.coerce(e[0]),"string"!=typeof e[0]&&e.unshift("%O");let i=0;e[0]=e[0].replace(/%([a-zA-Z%])/g,((r,u)=>{if("%%"===r)return"%";i++;const o=t.formatters[u];if("function"==typeof o){const t=e[i];r=o.call(n,t),e.splice(i,1),i--}return r})),t.formatArgs.call(n,e);(n.log||t.log).apply(n,e)}return s.namespace=e,s.useColors=t.useColors(),s.color=t.selectColor(e),s.extend=n,s.destroy=t.destroy,Object.defineProperty(s,"enabled",{enumerable:!0,configurable:!1,get:()=>null!==i?i:(u!==t.namespaces&&(u=t.namespaces,o=t.enabled(e)),o),set:e=>{i=e}}),"function"==typeof t.init&&t.init(s),s}function n(e,n){const r=t(this.namespace+(void 0===n?":":n)+e);return r.log=this.log,r}function r(e){return e.toString().substring(2,e.toString().length-2).replace(/\.\*\?$/,"*")}return t.debug=t,t.default=t,t.coerce=function(e){if(e instanceof Error)return e.stack||e.message;return e},t.disable=function(){const e=[...t.names.map(r),...t.skips.map(r).map((e=>"-"+e))].join(",");return t.enable(""),e},t.enable=function(e){let n;t.save(e),t.namespaces=e,t.names=[],t.skips=[];const r=("string"==typeof e?e:"").split(/[\s,]+/),u=r.length;for(n=0;n{t[n]=e[n]})),t.names=[],t.skips=[],t.formatters={},t.selectColor=function(e){let n=0;for(let t=0;t{const n=e.startsWith("-")?"":1===e.length?"-":"--",r=t.indexOf(n+e),u=t.indexOf("--");return-1!==r&&(-1===u||r{}),"Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."),t.colors=[6,2,3,4,5,1];try{const e=function(){if($r)return jr;$r=1;const e=E.default,t=A.default,n=Vr(),{env:r}=process;let u;function o(e){return 0!==e&&{level:e,hasBasic:!0,has256:e>=2,has16m:e>=3}}function i(t,o){if(0===u)return 0;if(n("color=16m")||n("color=full")||n("color=truecolor"))return 3;if(n("color=256"))return 2;if(t&&!o&&void 0===u)return 0;const i=u||0;if("dumb"===r.TERM)return i;if("win32"===process.platform){const t=e.release().split(".");return Number(t[0])>=10&&Number(t[2])>=10586?Number(t[2])>=14931?3:2:1}if("CI"in r)return["TRAVIS","CIRCLECI","APPVEYOR","GITLAB_CI","GITHUB_ACTIONS","BUILDKITE"].some((e=>e in r))||"codeship"===r.CI_NAME?1:i;if("TEAMCITY_VERSION"in r)return/^(9\.(0*[1-9]\d*)\.|\d{2,}\.)/.test(r.TEAMCITY_VERSION)?1:0;if("truecolor"===r.COLORTERM)return 3;if("TERM_PROGRAM"in r){const e=parseInt((r.TERM_PROGRAM_VERSION||"").split(".")[0],10);switch(r.TERM_PROGRAM){case"iTerm.app":return e>=3?3:2;case"Apple_Terminal":return 2}}return/-256(color)?$/i.test(r.TERM)?2:/^screen|^xterm|^vt100|^vt220|^rxvt|color|ansi|cygwin|linux/i.test(r.TERM)||"COLORTERM"in r?1:i}return n("no-color")||n("no-colors")||n("color=false")||n("color=never")?u=0:(n("color")||n("colors")||n("color=true")||n("color=always"))&&(u=1),"FORCE_COLOR"in r&&(u="true"===r.FORCE_COLOR?1:"false"===r.FORCE_COLOR?0:0===r.FORCE_COLOR.length?1:Math.min(parseInt(r.FORCE_COLOR,10),3)),jr={supportsColor:function(e){return o(i(e,e&&e.isTTY))},stdout:o(i(!0,t.isatty(1))),stderr:o(i(!0,t.isatty(2)))}}();e&&(e.stderr||e).level>=2&&(t.colors=[20,21,26,27,32,33,38,39,40,41,42,43,44,45,56,57,62,63,68,69,74,75,76,77,78,79,80,81,92,93,98,99,112,113,128,129,134,135,148,149,160,161,162,163,164,165,166,167,168,169,170,171,172,173,178,179,184,185,196,197,198,199,200,201,202,203,204,205,206,207,208,209,214,215,220,221])}catch(e){}t.inspectOpts=Object.keys(process.env).filter((e=>/^debug_/i.test(e))).reduce(((e,t)=>{const n=t.substring(6).toLowerCase().replace(/_([a-z])/g,((e,t)=>t.toUpperCase()));let r=process.env[t];return r=!!/^(yes|on|true|enabled)$/i.test(r)||!/^(no|off|false|disabled)$/i.test(r)&&("null"===r?null:Number(r)),e[n]=r,e}),{}),e.exports=Rr()(t);const{formatters:u}=e.exports;u.o=function(e){return this.inspectOpts.colors=this.useColors,r.inspect(e,this.inspectOpts).split("\n").map((e=>e.trim())).join(" ")},u.O=function(e){return this.inspectOpts.colors=this.useColors,r.inspect(e,this.inspectOpts)}}(Gr,Gr.exports)),Gr.exports}Jr=Nr,"undefined"==typeof process||"renderer"===process.type||!0===process.browser||process.__nwjs?Jr.exports=(Br||(Br=1,function(e,t){t.formatArgs=function(t){if(t[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+t[0]+(this.useColors?"%c ":" ")+"+"+e.exports.humanize(this.diff),!this.useColors)return;const n="color: "+this.color;t.splice(1,0,n,"color: inherit");let r=0,u=0;t[0].replace(/%[a-zA-Z%]/g,(e=>{"%%"!==e&&(r++,"%c"===e&&(u=r))})),t.splice(u,0,n)},t.save=function(e){try{e?t.storage.setItem("debug",e):t.storage.removeItem("debug")}catch(e){}},t.load=function(){let e;try{e=t.storage.getItem("debug")}catch(e){}return!e&&"undefined"!=typeof process&&"env"in process&&(e=process.env.DEBUG),e},t.useColors=function(){return!("undefined"==typeof window||!window.process||"renderer"!==window.process.type&&!window.process.__nwjs)||("undefined"==typeof navigator||!navigator.userAgent||!navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/))&&("undefined"!=typeof document&&document.documentElement&&document.documentElement.style&&document.documentElement.style.WebkitAppearance||"undefined"!=typeof window&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||"undefined"!=typeof navigator&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/)&&parseInt(RegExp.$1,10)>=31||"undefined"!=typeof navigator&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/))},t.storage=function(){try{return localStorage}catch(e){}}(),t.destroy=(()=>{let e=!1;return()=>{e||(e=!0,console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."))}})(),t.colors=["#0000CC","#0000FF","#0033CC","#0033FF","#0066CC","#0066FF","#0099CC","#0099FF","#00CC00","#00CC33","#00CC66","#00CC99","#00CCCC","#00CCFF","#3300CC","#3300FF","#3333CC","#3333FF","#3366CC","#3366FF","#3399CC","#3399FF","#33CC00","#33CC33","#33CC66","#33CC99","#33CCCC","#33CCFF","#6600CC","#6600FF","#6633CC","#6633FF","#66CC00","#66CC33","#9900CC","#9900FF","#9933CC","#9933FF","#99CC00","#99CC33","#CC0000","#CC0033","#CC0066","#CC0099","#CC00CC","#CC00FF","#CC3300","#CC3333","#CC3366","#CC3399","#CC33CC","#CC33FF","#CC6600","#CC6633","#CC9900","#CC9933","#CCCC00","#CCCC33","#FF0000","#FF0033","#FF0066","#FF0099","#FF00CC","#FF00FF","#FF3300","#FF3333","#FF3366","#FF3399","#FF33CC","#FF33FF","#FF6600","#FF6633","#FF9900","#FF9933","#FFCC00","#FFCC33"],t.log=console.debug||console.log||(()=>{}),e.exports=Rr()(t);const{formatters:n}=e.exports;n.j=function(e){try{return JSON.stringify(e)}catch(e){return"[UnexpectedJSONParseError]: "+e.message}}}(Ir,Ir.exports)),Ir.exports):Jr.exports=Ur();var Wr=function(e){return(e=e||{}).circles?function(e){var t=[],n=[];return e.proto?function e(u){if("object"!=typeof u||null===u)return u;if(u instanceof Date)return new Date(u);if(Array.isArray(u))return r(u,e);if(u instanceof Map)return new Map(r(Array.from(u),e));if(u instanceof Set)return new Set(r(Array.from(u),e));var o={};for(var i in t.push(u),n.push(o),u){var s=u[i];if("object"!=typeof s||null===s)o[i]=s;else if(s instanceof Date)o[i]=new Date(s);else if(s instanceof Map)o[i]=new Map(r(Array.from(s),e));else if(s instanceof Set)o[i]=new Set(r(Array.from(s),e));else if(ArrayBuffer.isView(s))o[i]=zr(s);else{var c=t.indexOf(s);o[i]=-1!==c?n[c]:e(s)}}return t.pop(),n.pop(),o}:function e(u){if("object"!=typeof u||null===u)return u;if(u instanceof Date)return new Date(u);if(Array.isArray(u))return r(u,e);if(u instanceof Map)return new Map(r(Array.from(u),e));if(u instanceof Set)return new Set(r(Array.from(u),e));var o={};for(var i in t.push(u),n.push(o),u)if(!1!==Object.hasOwnProperty.call(u,i)){var s=u[i];if("object"!=typeof s||null===s)o[i]=s;else if(s instanceof Date)o[i]=new Date(s);else if(s instanceof Map)o[i]=new Map(r(Array.from(s),e));else if(s instanceof Set)o[i]=new Set(r(Array.from(s),e));else if(ArrayBuffer.isView(s))o[i]=zr(s);else{var c=t.indexOf(s);o[i]=-1!==c?n[c]:e(s)}}return t.pop(),n.pop(),o};function r(e,r){for(var u=Object.keys(e),o=new Array(u.length),i=0;i!e,Qr=e=>e&&"object"==typeof e&&!Array.isArray(e),eu=(e,t,n)=>{(Array.isArray(t)?t:[t]).forEach((t=>{if(t)throw new Error(`Problem with log4js configuration: (${Kr.inspect(e,{depth:5})}) - ${n}`)}))};var tu={configure:e=>{qr("New configuration to be validated: ",e),eu(e,Zr(Qr(e)),"must be an object."),qr(`Calling pre-processing listeners (${Yr.length})`),Yr.forEach((t=>t(e))),qr("Configuration pre-processing finished."),qr(`Calling configuration listeners (${Xr.length})`),Xr.forEach((t=>t(e))),qr("Configuration finished.")},addListener:e=>{Xr.push(e),qr(`Added listener, now ${Xr.length} listeners`)},addPreProcessingListener:e=>{Yr.push(e),qr(`Added pre-processing listener, now ${Yr.length} listeners`)},throwExceptionIf:eu,anObject:Qr,anInteger:e=>e&&"number"==typeof e&&Number.isInteger(e),validIdentifier:e=>/^[A-Za-z][A-Za-z0-9_]*$/g.test(e),not:Zr},nu={exports:{}};!function(e){function t(e,t){for(var n=e.toString();n.length-1?s:c,l=n(u.getHours()),f=n(u.getMinutes()),d=n(u.getSeconds()),D=t(u.getMilliseconds(),3),p=function(e){var t=Math.abs(e),n=String(Math.floor(t/60)),r=String(t%60);return n=("0"+n).slice(-2),r=("0"+r).slice(-2),0===e?"Z":(e<0?"+":"-")+n+":"+r}(u.getTimezoneOffset());return r.replace(/dd/g,o).replace(/MM/g,i).replace(/y{1,4}/g,a).replace(/hh/g,l).replace(/mm/g,f).replace(/ss/g,d).replace(/SSS/g,D).replace(/O/g,p)}function u(e,t,n,r){e["set"+(r?"":"UTC")+t](n)}e.exports=r,e.exports.asString=r,e.exports.parse=function(t,n,r){if(!t)throw new Error("pattern must be supplied");return function(t,n,r){var o=t.indexOf("O")<0,i=!1,s=[{pattern:/y{1,4}/,regexp:"\\d{1,4}",fn:function(e,t){u(e,"FullYear",t,o)}},{pattern:/MM/,regexp:"\\d{1,2}",fn:function(e,t){u(e,"Month",t-1,o),e.getMonth()!==t-1&&(i=!0)}},{pattern:/dd/,regexp:"\\d{1,2}",fn:function(e,t){i&&u(e,"Month",e.getMonth()-1,o),u(e,"Date",t,o)}},{pattern:/hh/,regexp:"\\d{1,2}",fn:function(e,t){u(e,"Hours",t,o)}},{pattern:/mm/,regexp:"\\d\\d",fn:function(e,t){u(e,"Minutes",t,o)}},{pattern:/ss/,regexp:"\\d\\d",fn:function(e,t){u(e,"Seconds",t,o)}},{pattern:/SSS/,regexp:"\\d\\d\\d",fn:function(e,t){u(e,"Milliseconds",t,o)}},{pattern:/O/,regexp:"[+-]\\d{1,2}:?\\d{2}?|Z",fn:function(e,t){t="Z"===t?0:t.replace(":","");var n=Math.abs(t),r=(t>0?-1:1)*(n%100+60*Math.floor(n/100));e.setUTCMinutes(e.getUTCMinutes()+r)}}],c=s.reduce((function(e,t){return t.pattern.test(e.regexp)?(t.index=e.regexp.match(t.pattern).index,e.regexp=e.regexp.replace(t.pattern,"("+t.regexp+")")):t.index=-1,e}),{regexp:t,index:[]}),a=s.filter((function(e){return e.index>-1}));a.sort((function(e,t){return e.index-t.index}));var l=new RegExp(c.regexp).exec(n);if(l){var f=r||e.exports.now();return a.forEach((function(e,t){e.fn(f,l[t+1])})),f}throw new Error("String '"+n+"' could not be parsed as '"+t+"'")}(t,n,r)},e.exports.now=function(){return new Date},e.exports.ISO8601_FORMAT="yyyy-MM-ddThh:mm:ss.SSS",e.exports.ISO8601_WITH_TZ_OFFSET_FORMAT="yyyy-MM-ddThh:mm:ss.SSSO",e.exports.DATETIME_FORMAT="dd MM yyyy hh:mm:ss.SSS",e.exports.ABSOLUTETIME_FORMAT="hh:mm:ss.SSS"}(nu);const ru=nu.exports,uu=E.default,ou=F.default,iu=p.default,su={bold:[1,22],italic:[3,23],underline:[4,24],inverse:[7,27],white:[37,39],grey:[90,39],black:[90,39],blue:[34,39],cyan:[36,39],green:[32,39],magenta:[35,39],red:[91,39],yellow:[33,39]};function cu(e){return e?`[${su[e][0]}m`:""}function au(e){return e?`[${su[e][1]}m`:""}function lu(e,t){return n=ou.format("[%s] [%s] %s - ",ru.asString(e.startTime),e.level.toString(),e.categoryName),cu(r=t)+n+au(r);var n,r}function fu(e){return lu(e)+ou.format(...e.data)}function du(e){return lu(e,e.level.colour)+ou.format(...e.data)}function Du(e){return ou.format(...e.data)}function pu(e){return e.data[0]}function Eu(e,t){const n=/%(-?[0-9]+)?(\.?-?[0-9]+)?([[\]cdhmnprzxXyflos%])(\{([^}]+)\})?|([^%]+)/;function r(e){return e&&e.pid?e.pid.toString():process.pid.toString()}e=e||"%r %p %c - %m%n";const u={c:function(e,t){let n=e.categoryName;if(t){const e=parseInt(t,10),r=n.split(".");ee&&(n=r.slice(-e).join(iu.sep))}return n},l:function(e){return e.lineNumber?`${e.lineNumber}`:""},o:function(e){return e.columnNumber?`${e.columnNumber}`:""},s:function(e){return e.callStack||""}};function o(e,t,n){return u[e](t,n)}function i(e,t,n){let r=e;return r=function(e,t){let n;return e?(n=parseInt(e.substr(1),10),n>0?t.slice(0,n):t.slice(n)):t}(t,r),r=function(e,t){let n;if(e)if("-"===e.charAt(0))for(n=parseInt(e.substr(1),10);t.lengthDu,basic:()=>fu,colored:()=>du,coloured:()=>du,pattern:e=>Eu(e&&e.pattern,e&&e.tokens),dummy:()=>pu};var hu={basicLayout:fu,messagePassThroughLayout:Du,patternLayout:Eu,colouredLayout:du,coloredLayout:du,dummyLayout:pu,addLayout(e,t){mu[e]=t},layout:(e,t)=>mu[e]&&mu[e](t)};const yu=tu,Cu=["white","grey","black","blue","cyan","green","magenta","red","yellow"];class Fu{constructor(e,t,n){this.level=e,this.levelStr=t,this.colour=n}toString(){return this.levelStr}static getLevel(e,t){return e?e instanceof Fu?e:(e instanceof Object&&e.levelStr&&(e=e.levelStr),Fu[e.toString().toUpperCase()]||t):t}static addLevels(e){if(e){Object.keys(e).forEach((t=>{const n=t.toUpperCase();Fu[n]=new Fu(e[t].value,n,e[t].colour);const r=Fu.levels.findIndex((e=>e.levelStr===n));r>-1?Fu.levels[r]=Fu[n]:Fu.levels.push(Fu[n])})),Fu.levels.sort(((e,t)=>e.level-t.level))}}isLessThanOrEqualTo(e){return"string"==typeof e&&(e=Fu.getLevel(e)),this.level<=e.level}isGreaterThanOrEqualTo(e){return"string"==typeof e&&(e=Fu.getLevel(e)),this.level>=e.level}isEqualTo(e){return"string"==typeof e&&(e=Fu.getLevel(e)),this.level===e.level}}Fu.levels=[],Fu.addLevels({ALL:{value:Number.MIN_VALUE,colour:"grey"},TRACE:{value:5e3,colour:"blue"},DEBUG:{value:1e4,colour:"cyan"},INFO:{value:2e4,colour:"green"},WARN:{value:3e4,colour:"yellow"},ERROR:{value:4e4,colour:"red"},FATAL:{value:5e4,colour:"magenta"},MARK:{value:9007199254740992,colour:"grey"},OFF:{value:Number.MAX_VALUE,colour:"grey"}}),yu.addListener((e=>{const t=e.levels;if(t){yu.throwExceptionIf(e,yu.not(yu.anObject(t)),"levels must be an object");Object.keys(t).forEach((n=>{yu.throwExceptionIf(e,yu.not(yu.validIdentifier(n)),`level name "${n}" is not a valid identifier (must start with a letter, only contain A-Z,a-z,0-9,_)`),yu.throwExceptionIf(e,yu.not(yu.anObject(t[n])),`level "${n}" must be an object`),yu.throwExceptionIf(e,yu.not(t[n].value),`level "${n}" must have a 'value' property`),yu.throwExceptionIf(e,yu.not(yu.anInteger(t[n].value)),`level "${n}".value must have an integer value`),yu.throwExceptionIf(e,yu.not(t[n].colour),`level "${n}" must have a 'colour' property`),yu.throwExceptionIf(e,yu.not(Cu.indexOf(t[n].colour)>-1),`level "${n}".colour must be one of ${Cu.join(", ")}`)}))}})),yu.addListener((e=>{Fu.addLevels(e.levels)}));var gu=Fu,Au={exports:{}},vu={};/*! (c) 2020 Andrea Giammarchi */
-const{parse:Su,stringify:wu}=JSON,{keys:Ou}=Object,bu=String,_u="string",Bu={},Pu="object",ku=(e,t)=>t,xu=e=>e instanceof bu?bu(e):e,Nu=(e,t)=>typeof t===_u?new bu(t):t,Iu=(e,t,n,r)=>{const u=[];for(let o=Ou(n),{length:i}=o,s=0;s{const r=bu(t.push(n)-1);return e.set(n,r),r},Ru=(e,t)=>{const n=Su(e,Nu).map(xu),r=n[0],u=t||ku,o=typeof r===Pu&&r?Iu(n,new Set,r,u):r;return u.call({"":o},"",o)};vu.parse=Ru;const Mu=(e,t,n)=>{const r=t&&typeof t===Pu?(e,n)=>""===e||-1Su(Mu(e));vu.fromJSON=e=>Ru(wu(e));const Lu=vu,ju=gu;class $u{constructor(e,t,n,r,u){this.startTime=new Date,this.categoryName=e,this.data=n,this.level=t,this.context=Object.assign({},r),this.pid=process.pid,u&&(this.functionName=u.functionName,this.fileName=u.fileName,this.lineNumber=u.lineNumber,this.columnNumber=u.columnNumber,this.callStack=u.callStack)}serialise(){const e=this.data.map((e=>(e&&e.message&&e.stack&&(e=Object.assign({message:e.message,stack:e.stack},e)),e)));return this.data=e,Lu.stringify(this)}static deserialise(e){let t;try{const n=Lu.parse(e);n.data=n.data.map((e=>{if(e&&e.message&&e.stack){const t=new Error(e);Object.keys(e).forEach((n=>{t[n]=e[n]})),e=t}return e})),t=new $u(n.categoryName,ju.getLevel(n.level.levelStr),n.data,n.context),t.startTime=new Date(n.startTime),t.pid=n.pid,t.cluster=n.cluster}catch(n){t=new $u("log4js",ju.ERROR,["Unable to parse log:",e,"because: ",n])}return t}}var Hu=$u;const Ju=Nr.exports("log4js:clustering"),Gu=Hu,Vu=tu;let Uu=!1,Wu=null;try{Wu=require("cluster")}catch(e){Ju("cluster module not present"),Uu=!0}const zu=[];let Ku=!1,qu="NODE_APP_INSTANCE";const Yu=()=>Ku&&"0"===process.env[qu],Xu=()=>Uu||Wu.isMaster||Yu(),Zu=e=>{zu.forEach((t=>t(e)))},Qu=(e,t)=>{if(Ju("cluster message received from worker ",e,": ",t),e.topic&&e.data&&(t=e,e=void 0),t&&t.topic&&"log4js:message"===t.topic){Ju("received message: ",t.data);const e=Gu.deserialise(t.data);Zu(e)}};Uu||Vu.addListener((e=>{zu.length=0,({pm2:Ku,disableClustering:Uu,pm2InstanceVar:qu="NODE_APP_INSTANCE"}=e),Ju(`clustering disabled ? ${Uu}`),Ju(`cluster.isMaster ? ${Wu&&Wu.isMaster}`),Ju(`pm2 enabled ? ${Ku}`),Ju(`pm2InstanceVar = ${qu}`),Ju(`process.env[${qu}] = ${process.env[qu]}`),Ku&&process.removeListener("message",Qu),Wu&&Wu.removeListener&&Wu.removeListener("message",Qu),Uu||e.disableClustering?Ju("Not listening for cluster messages, because clustering disabled."):Yu()?(Ju("listening for PM2 broadcast messages"),process.on("message",Qu)):Wu.isMaster?(Ju("listening for cluster messages"),Wu.on("message",Qu)):Ju("not listening for messages, because we are not a master process")}));var eo={onlyOnMaster:(e,t)=>Xu()?e():t,isMaster:Xu,send:e=>{Xu()?Zu(e):(Ku||(e.cluster={workerId:Wu.worker.id,worker:process.pid}),process.send({topic:"log4js:message",data:e.serialise()}))},onMessage:e=>{zu.push(e)}},to={};function no(e){if("number"==typeof e&&Number.isInteger(e))return e;const t={K:1024,M:1048576,G:1073741824},n=Object.keys(t),r=e.substr(e.length-1).toLocaleUpperCase(),u=e.substring(0,e.length-1).trim();if(n.indexOf(r)<0||!Number.isInteger(Number(u)))throw Error(`maxLogSize: "${e}" is invalid`);return u*t[r]}function ro(e){return function(e,t){const n=Object.assign({},t);return Object.keys(e).forEach((r=>{n[r]&&(n[r]=e[r](t[r]))})),n}({maxLogSize:no},e)}const uo={file:ro,fileSync:ro};to.modifyConfig=e=>uo[e.type]?uo[e.type](e):e;var oo={};const io=console.log.bind(console);oo.configure=function(e,t){let n=t.colouredLayout;return e.layout&&(n=t.layout(e.layout.type,e.layout)),function(e,t){return n=>{io(e(n,t))}}(n,e.timezoneOffset)};var so={};so.configure=function(e,t){let n=t.colouredLayout;return e.layout&&(n=t.layout(e.layout.type,e.layout)),function(e,t){return n=>{process.stdout.write(`${e(n,t)}\n`)}}(n,e.timezoneOffset)};var co={};co.configure=function(e,t){let n=t.colouredLayout;return e.layout&&(n=t.layout(e.layout.type,e.layout)),function(e,t){return n=>{process.stderr.write(`${e(n,t)}\n`)}}(n,e.timezoneOffset)};var ao={};ao.configure=function(e,t,n,r){const u=n(e.appender);return function(e,t,n,r){const u=r.getLevel(e),o=r.getLevel(t,r.FATAL);return e=>{const t=e.level;t.isGreaterThanOrEqualTo(u)&&t.isLessThanOrEqualTo(o)&&n(e)}}(e.level,e.maxLevel,u,r)};var lo={};const fo=Nr.exports("log4js:categoryFilter");lo.configure=function(e,t,n){const r=n(e.appender);return function(e,t){return"string"==typeof e&&(e=[e]),n=>{fo(`Checking ${n.categoryName} against ${e}`),-1===e.indexOf(n.categoryName)&&(fo("Not excluded, sending to appender"),t(n))}}(e.exclude,r)};var Do={};const po=Nr.exports("log4js:noLogFilter");Do.configure=function(e,t,n){const r=n(e.appender);return function(e,t){return n=>{po(`Checking data: ${n.data} against filters: ${e}`),"string"==typeof e&&(e=[e]),e=e.filter((e=>null!=e&&""!==e));const r=new RegExp(e.join("|"),"i");(0===e.length||n.data.findIndex((e=>r.test(e)))<0)&&(po("Not excluded, sending to appender"),t(n))}}(e.exclude,r)};var Eo={},mo={exports:{}},ho={},yo={fromCallback:function(e){return Object.defineProperty((function(){if("function"!=typeof arguments[arguments.length-1])return new Promise(((t,n)=>{arguments[arguments.length]=(e,r)=>{if(e)return n(e);t(r)},arguments.length++,e.apply(this,arguments)}));e.apply(this,arguments)}),"name",{value:e.name})},fromPromise:function(e){return Object.defineProperty((function(){const t=arguments[arguments.length-1];if("function"!=typeof t)return e.apply(this,arguments);e.apply(this,arguments).then((e=>t(null,e)),t)}),"name",{value:e.name})}};!function(e){const t=yo.fromCallback,n=we,r=["access","appendFile","chmod","chown","close","copyFile","fchmod","fchown","fdatasync","fstat","fsync","ftruncate","futimes","lchown","lchmod","link","lstat","mkdir","mkdtemp","open","readFile","readdir","readlink","realpath","rename","rmdir","stat","symlink","truncate","unlink","utimes","writeFile"].filter((e=>"function"==typeof n[e]));Object.keys(n).forEach((t=>{"promises"!==t&&(e[t]=n[t])})),r.forEach((r=>{e[r]=t(n[r])})),e.exists=function(e,t){return"function"==typeof t?n.exists(e,t):new Promise((t=>n.exists(e,t)))},e.read=function(e,t,r,u,o,i){return"function"==typeof i?n.read(e,t,r,u,o,i):new Promise(((i,s)=>{n.read(e,t,r,u,o,((e,t,n)=>{if(e)return s(e);i({bytesRead:t,buffer:n})}))}))},e.write=function(e,t,...r){return"function"==typeof r[r.length-1]?n.write(e,t,...r):new Promise(((u,o)=>{n.write(e,t,...r,((e,t,n)=>{if(e)return o(e);u({bytesWritten:t,buffer:n})}))}))},"function"==typeof n.realpath.native&&(e.realpath.native=t(n.realpath.native))}(ho);const Co=p.default;function Fo(e){return(e=Co.normalize(Co.resolve(e)).split(Co.sep)).length>0?e[0]:null}const go=/[<>:"|?*]/;var Ao=function(e){const t=Fo(e);return e=e.replace(t,""),go.test(e)};const vo=we,So=p.default,wo=Ao,Oo=parseInt("0777",8);var bo=function e(t,n,r,u){if("function"==typeof n?(r=n,n={}):n&&"object"==typeof n||(n={mode:n}),"win32"===process.platform&&wo(t)){const e=new Error(t+" contains invalid WIN32 path characters.");return e.code="EINVAL",r(e)}let o=n.mode;const i=n.fs||vo;void 0===o&&(o=Oo&~process.umask()),u||(u=null),r=r||function(){},t=So.resolve(t),i.mkdir(t,o,(o=>{if(!o)return r(null,u=u||t);if("ENOENT"===o.code){if(So.dirname(t)===t)return r(o);e(So.dirname(t),n,((u,o)=>{u?r(u,o):e(t,n,r,o)}))}else i.stat(t,((e,t)=>{e||!t.isDirectory()?r(o,u):r(null,u)}))}))};const _o=we,Bo=p.default,Po=Ao,ko=parseInt("0777",8);var xo=function e(t,n,r){n&&"object"==typeof n||(n={mode:n});let u=n.mode;const o=n.fs||_o;if("win32"===process.platform&&Po(t)){const e=new Error(t+" contains invalid WIN32 path characters.");throw e.code="EINVAL",e}void 0===u&&(u=ko&~process.umask()),r||(r=null),t=Bo.resolve(t);try{o.mkdirSync(t,u),r=r||t}catch(u){if("ENOENT"===u.code){if(Bo.dirname(t)===t)throw u;r=e(Bo.dirname(t),n,r),e(t,n,r)}else{let e;try{e=o.statSync(t)}catch(e){throw u}if(!e.isDirectory())throw u}}return r};const No=(0,yo.fromCallback)(bo);var Io={mkdirs:No,mkdirsSync:xo,mkdirp:No,mkdirpSync:xo,ensureDir:No,ensureDirSync:xo};const To=we;E.default,p.default;var Ro=function(e,t,n,r){To.open(e,"r+",((e,u)=>{if(e)return r(e);To.futimes(u,t,n,(e=>{To.close(u,(t=>{r&&r(e||t)}))}))}))},Mo=function(e,t,n){const r=To.openSync(e,"r+");return To.futimesSync(r,t,n),To.closeSync(r)};const Lo=we,jo=p.default,$o=10,Ho=5,Jo=0,Go=process.versions.node.split("."),Vo=Number.parseInt(Go[0],10),Uo=Number.parseInt(Go[1],10),Wo=Number.parseInt(Go[2],10);function zo(){if(Vo>$o)return!0;if(Vo===$o){if(Uo>Ho)return!0;if(Uo===Ho&&Wo>=Jo)return!0}return!1}function Ko(e,t){const n=jo.resolve(e).split(jo.sep).filter((e=>e)),r=jo.resolve(t).split(jo.sep).filter((e=>e));return n.reduce(((e,t,n)=>e&&r[n]===t),!0)}function qo(e,t,n){return`Cannot ${n} '${e}' to a subdirectory of itself, '${t}'.`}var Yo,Xo,Zo={checkPaths:function(e,t,n,r){!function(e,t,n){zo()?Lo.stat(e,{bigint:!0},((e,r)=>{if(e)return n(e);Lo.stat(t,{bigint:!0},((e,t)=>e?"ENOENT"===e.code?n(null,{srcStat:r,destStat:null}):n(e):n(null,{srcStat:r,destStat:t})))})):Lo.stat(e,((e,r)=>{if(e)return n(e);Lo.stat(t,((e,t)=>e?"ENOENT"===e.code?n(null,{srcStat:r,destStat:null}):n(e):n(null,{srcStat:r,destStat:t})))}))}(e,t,((u,o)=>{if(u)return r(u);const{srcStat:i,destStat:s}=o;return s&&s.ino&&s.dev&&s.ino===i.ino&&s.dev===i.dev?r(new Error("Source and destination must not be the same.")):i.isDirectory()&&Ko(e,t)?r(new Error(qo(e,t,n))):r(null,{srcStat:i,destStat:s})}))},checkPathsSync:function(e,t,n){const{srcStat:r,destStat:u}=function(e,t){let n,r;n=zo()?Lo.statSync(e,{bigint:!0}):Lo.statSync(e);try{r=zo()?Lo.statSync(t,{bigint:!0}):Lo.statSync(t)}catch(e){if("ENOENT"===e.code)return{srcStat:n,destStat:null};throw e}return{srcStat:n,destStat:r}}(e,t);if(u&&u.ino&&u.dev&&u.ino===r.ino&&u.dev===r.dev)throw new Error("Source and destination must not be the same.");if(r.isDirectory()&&Ko(e,t))throw new Error(qo(e,t,n));return{srcStat:r,destStat:u}},checkParentPaths:function e(t,n,r,u,o){const i=jo.resolve(jo.dirname(t)),s=jo.resolve(jo.dirname(r));if(s===i||s===jo.parse(s).root)return o();zo()?Lo.stat(s,{bigint:!0},((i,c)=>i?"ENOENT"===i.code?o():o(i):c.ino&&c.dev&&c.ino===n.ino&&c.dev===n.dev?o(new Error(qo(t,r,u))):e(t,n,s,u,o))):Lo.stat(s,((i,c)=>i?"ENOENT"===i.code?o():o(i):c.ino&&c.dev&&c.ino===n.ino&&c.dev===n.dev?o(new Error(qo(t,r,u))):e(t,n,s,u,o)))},checkParentPathsSync:function e(t,n,r,u){const o=jo.resolve(jo.dirname(t)),i=jo.resolve(jo.dirname(r));if(i===o||i===jo.parse(i).root)return;let s;try{s=zo()?Lo.statSync(i,{bigint:!0}):Lo.statSync(i)}catch(e){if("ENOENT"===e.code)return;throw e}if(s.ino&&s.dev&&s.ino===n.ino&&s.dev===n.dev)throw new Error(qo(t,r,u));return e(t,n,i,u)},isSrcSubdir:Ko};const Qo=we,ei=p.default,ti=Io.mkdirsSync,ni=Mo,ri=Zo;function ui(e,t,n,r){if(!r.filter||r.filter(t,n))return function(e,t,n,r){const u=r.dereference?Qo.statSync:Qo.lstatSync,o=u(t);if(o.isDirectory())return function(e,t,n,r,u){if(!t)return function(e,t,n,r){return Qo.mkdirSync(n),ii(t,n,r),Qo.chmodSync(n,e.mode)}(e,n,r,u);if(t&&!t.isDirectory())throw new Error(`Cannot overwrite non-directory '${r}' with directory '${n}'.`);return ii(n,r,u)}(o,e,t,n,r);if(o.isFile()||o.isCharacterDevice()||o.isBlockDevice())return function(e,t,n,r,u){return t?function(e,t,n,r){if(r.overwrite)return Qo.unlinkSync(n),oi(e,t,n,r);if(r.errorOnExist)throw new Error(`'${n}' already exists`)}(e,n,r,u):oi(e,n,r,u)}(o,e,t,n,r);if(o.isSymbolicLink())return function(e,t,n,r){let u=Qo.readlinkSync(t);r.dereference&&(u=ei.resolve(process.cwd(),u));if(e){let e;try{e=Qo.readlinkSync(n)}catch(e){if("EINVAL"===e.code||"UNKNOWN"===e.code)return Qo.symlinkSync(u,n);throw e}if(r.dereference&&(e=ei.resolve(process.cwd(),e)),ri.isSrcSubdir(u,e))throw new Error(`Cannot copy '${u}' to a subdirectory of itself, '${e}'.`);if(Qo.statSync(n).isDirectory()&&ri.isSrcSubdir(e,u))throw new Error(`Cannot overwrite '${e}' with '${u}'.`);return function(e,t){return Qo.unlinkSync(t),Qo.symlinkSync(e,t)}(u,n)}return Qo.symlinkSync(u,n)}(e,t,n,r)}(e,t,n,r)}function oi(e,t,n,r){return"function"==typeof Qo.copyFileSync?(Qo.copyFileSync(t,n),Qo.chmodSync(n,e.mode),r.preserveTimestamps?ni(n,e.atime,e.mtime):void 0):function(e,t,n,r){const u=65536,o=(Xo?Yo:(Xo=1,Yo=function(e){if("function"==typeof Buffer.allocUnsafe)try{return Buffer.allocUnsafe(e)}catch(t){return new Buffer(e)}return new Buffer(e)}))(u),i=Qo.openSync(t,"r"),s=Qo.openSync(n,"w",e.mode);let c=0;for(;cfunction(e,t,n,r){const u=ei.join(t,e),o=ei.join(n,e),{destStat:i}=ri.checkPathsSync(u,o,"copy");return ui(i,u,o,r)}(r,e,t,n)))}var si=function(e,t,n){"function"==typeof n&&(n={filter:n}),(n=n||{}).clobber=!("clobber"in n)||!!n.clobber,n.overwrite="overwrite"in n?!!n.overwrite:n.clobber,n.preserveTimestamps&&"ia32"===process.arch&&console.warn("fs-extra: Using the preserveTimestamps option in 32-bit node is not recommended;\n\n see https://github.com/jprichardson/node-fs-extra/issues/269");const{srcStat:r,destStat:u}=ri.checkPathsSync(e,t,"copy");return ri.checkParentPathsSync(e,r,t,"copy"),function(e,t,n,r){if(r.filter&&!r.filter(t,n))return;const u=ei.dirname(n);Qo.existsSync(u)||ti(u);return ui(e,t,n,r)}(u,e,t,n)},ci={copySync:si};const ai=yo.fromPromise,li=ho;var fi={pathExists:ai((function(e){return li.access(e).then((()=>!0)).catch((()=>!1))})),pathExistsSync:li.existsSync};const di=we,Di=p.default,pi=Io.mkdirs,Ei=fi.pathExists,mi=Ro,hi=Zo;function yi(e,t,n,r,u){const o=Di.dirname(n);Ei(o,((i,s)=>i?u(i):s?Fi(e,t,n,r,u):void pi(o,(o=>o?u(o):Fi(e,t,n,r,u)))))}function Ci(e,t,n,r,u,o){Promise.resolve(u.filter(n,r)).then((i=>i?e(t,n,r,u,o):o()),(e=>o(e)))}function Fi(e,t,n,r,u){return r.filter?Ci(gi,e,t,n,r,u):gi(e,t,n,r,u)}function gi(e,t,n,r,u){(r.dereference?di.stat:di.lstat)(t,((o,i)=>o?u(o):i.isDirectory()?function(e,t,n,r,u,o){if(!t)return function(e,t,n,r,u){di.mkdir(n,(o=>{if(o)return u(o);Si(t,n,r,(t=>t?u(t):di.chmod(n,e.mode,u)))}))}(e,n,r,u,o);if(t&&!t.isDirectory())return o(new Error(`Cannot overwrite non-directory '${r}' with directory '${n}'.`));return Si(n,r,u,o)}(i,e,t,n,r,u):i.isFile()||i.isCharacterDevice()||i.isBlockDevice()?function(e,t,n,r,u,o){return t?function(e,t,n,r,u){if(!r.overwrite)return r.errorOnExist?u(new Error(`'${n}' already exists`)):u();di.unlink(n,(o=>o?u(o):Ai(e,t,n,r,u)))}(e,n,r,u,o):Ai(e,n,r,u,o)}(i,e,t,n,r,u):i.isSymbolicLink()?function(e,t,n,r,u){di.readlink(t,((t,o)=>t?u(t):(r.dereference&&(o=Di.resolve(process.cwd(),o)),e?void di.readlink(n,((t,i)=>t?"EINVAL"===t.code||"UNKNOWN"===t.code?di.symlink(o,n,u):u(t):(r.dereference&&(i=Di.resolve(process.cwd(),i)),hi.isSrcSubdir(o,i)?u(new Error(`Cannot copy '${o}' to a subdirectory of itself, '${i}'.`)):e.isDirectory()&&hi.isSrcSubdir(i,o)?u(new Error(`Cannot overwrite '${i}' with '${o}'.`)):function(e,t,n){di.unlink(t,(r=>r?n(r):di.symlink(e,t,n)))}(o,n,u)))):di.symlink(o,n,u))))}(e,t,n,r,u):void 0))}function Ai(e,t,n,r,u){return"function"==typeof di.copyFile?di.copyFile(t,n,(t=>t?u(t):vi(e,n,r,u))):function(e,t,n,r,u){const o=di.createReadStream(t);o.on("error",(e=>u(e))).once("open",(()=>{const t=di.createWriteStream(n,{mode:e.mode});t.on("error",(e=>u(e))).on("open",(()=>o.pipe(t))).once("close",(()=>vi(e,n,r,u)))}))}(e,t,n,r,u)}function vi(e,t,n,r){di.chmod(t,e.mode,(u=>u?r(u):n.preserveTimestamps?mi(t,e.atime,e.mtime,r):r()))}function Si(e,t,n,r){di.readdir(e,((u,o)=>u?r(u):wi(o,e,t,n,r)))}function wi(e,t,n,r,u){const o=e.pop();return o?function(e,t,n,r,u,o){const i=Di.join(n,t),s=Di.join(r,t);hi.checkPaths(i,s,"copy",((t,c)=>{if(t)return o(t);const{destStat:a}=c;Fi(a,i,s,u,(t=>t?o(t):wi(e,n,r,u,o)))}))}(e,o,t,n,r,u):u()}var Oi=function(e,t,n,r){"function"!=typeof n||r?"function"==typeof n&&(n={filter:n}):(r=n,n={}),r=r||function(){},(n=n||{}).clobber=!("clobber"in n)||!!n.clobber,n.overwrite="overwrite"in n?!!n.overwrite:n.clobber,n.preserveTimestamps&&"ia32"===process.arch&&console.warn("fs-extra: Using the preserveTimestamps option in 32-bit node is not recommended;\n\n see https://github.com/jprichardson/node-fs-extra/issues/269"),hi.checkPaths(e,t,"copy",((u,o)=>{if(u)return r(u);const{srcStat:i,destStat:s}=o;hi.checkParentPaths(e,i,t,"copy",(u=>u?r(u):n.filter?Ci(yi,s,e,t,n,r):yi(s,e,t,n,r)))}))};var bi={copy:(0,yo.fromCallback)(Oi)};const _i=we,Bi=p.default,Pi=g.default,ki="win32"===process.platform;function xi(e){["unlink","chmod","stat","lstat","rmdir","readdir"].forEach((t=>{e[t]=e[t]||_i[t],e[t+="Sync"]=e[t]||_i[t]})),e.maxBusyTries=e.maxBusyTries||3}function Ni(e,t,n){let r=0;"function"==typeof t&&(n=t,t={}),Pi(e,"rimraf: missing path"),Pi.strictEqual(typeof e,"string","rimraf: path should be a string"),Pi.strictEqual(typeof n,"function","rimraf: callback function required"),Pi(t,"rimraf: invalid options argument provided"),Pi.strictEqual(typeof t,"object","rimraf: options should be object"),xi(t),Ii(e,t,(function u(o){if(o){if(("EBUSY"===o.code||"ENOTEMPTY"===o.code||"EPERM"===o.code)&&rIi(e,t,u)),100*r)}"ENOENT"===o.code&&(o=null)}n(o)}))}function Ii(e,t,n){Pi(e),Pi(t),Pi("function"==typeof n),t.lstat(e,((r,u)=>r&&"ENOENT"===r.code?n(null):r&&"EPERM"===r.code&&ki?Ti(e,t,r,n):u&&u.isDirectory()?Mi(e,t,r,n):void t.unlink(e,(r=>{if(r){if("ENOENT"===r.code)return n(null);if("EPERM"===r.code)return ki?Ti(e,t,r,n):Mi(e,t,r,n);if("EISDIR"===r.code)return Mi(e,t,r,n)}return n(r)}))))}function Ti(e,t,n,r){Pi(e),Pi(t),Pi("function"==typeof r),n&&Pi(n instanceof Error),t.chmod(e,438,(u=>{u?r("ENOENT"===u.code?null:n):t.stat(e,((u,o)=>{u?r("ENOENT"===u.code?null:n):o.isDirectory()?Mi(e,t,n,r):t.unlink(e,r)}))}))}function Ri(e,t,n){let r;Pi(e),Pi(t),n&&Pi(n instanceof Error);try{t.chmodSync(e,438)}catch(e){if("ENOENT"===e.code)return;throw n}try{r=t.statSync(e)}catch(e){if("ENOENT"===e.code)return;throw n}r.isDirectory()?ji(e,t,n):t.unlinkSync(e)}function Mi(e,t,n,r){Pi(e),Pi(t),n&&Pi(n instanceof Error),Pi("function"==typeof r),t.rmdir(e,(u=>{!u||"ENOTEMPTY"!==u.code&&"EEXIST"!==u.code&&"EPERM"!==u.code?u&&"ENOTDIR"===u.code?r(n):r(u):function(e,t,n){Pi(e),Pi(t),Pi("function"==typeof n),t.readdir(e,((r,u)=>{if(r)return n(r);let o,i=u.length;if(0===i)return t.rmdir(e,n);u.forEach((r=>{Ni(Bi.join(e,r),t,(r=>{if(!o)return r?n(o=r):void(0==--i&&t.rmdir(e,n))}))}))}))}(e,t,r)}))}function Li(e,t){let n;xi(t=t||{}),Pi(e,"rimraf: missing path"),Pi.strictEqual(typeof e,"string","rimraf: path should be a string"),Pi(t,"rimraf: missing options"),Pi.strictEqual(typeof t,"object","rimraf: options should be object");try{n=t.lstatSync(e)}catch(n){if("ENOENT"===n.code)return;"EPERM"===n.code&&ki&&Ri(e,t,n)}try{n&&n.isDirectory()?ji(e,t,null):t.unlinkSync(e)}catch(n){if("ENOENT"===n.code)return;if("EPERM"===n.code)return ki?Ri(e,t,n):ji(e,t,n);if("EISDIR"!==n.code)throw n;ji(e,t,n)}}function ji(e,t,n){Pi(e),Pi(t),n&&Pi(n instanceof Error);try{t.rmdirSync(e)}catch(r){if("ENOTDIR"===r.code)throw n;if("ENOTEMPTY"===r.code||"EEXIST"===r.code||"EPERM"===r.code)!function(e,t){if(Pi(e),Pi(t),t.readdirSync(e).forEach((n=>Li(Bi.join(e,n),t))),!ki){return t.rmdirSync(e,t)}{const n=Date.now();do{try{return t.rmdirSync(e,t)}catch(e){}}while(Date.now()-n<500)}}(e,t);else if("ENOENT"!==r.code)throw r}}var $i=Ni;Ni.sync=Li;const Hi=$i;var Ji={remove:(0,yo.fromCallback)(Hi),removeSync:Hi.sync};const Gi=yo.fromCallback,Vi=we,Ui=p.default,Wi=Io,zi=Ji,Ki=Gi((function(e,t){t=t||function(){},Vi.readdir(e,((n,r)=>{if(n)return Wi.mkdirs(e,t);r=r.map((t=>Ui.join(e,t))),function e(){const n=r.pop();if(!n)return t();zi.remove(n,(n=>{if(n)return t(n);e()}))}()}))}));function qi(e){let t;try{t=Vi.readdirSync(e)}catch(t){return Wi.mkdirsSync(e)}t.forEach((t=>{t=Ui.join(e,t),zi.removeSync(t)}))}var Yi={emptyDirSync:qi,emptydirSync:qi,emptyDir:Ki,emptydir:Ki};const Xi=yo.fromCallback,Zi=p.default,Qi=we,es=Io,ts=fi.pathExists;var ns={createFile:Xi((function(e,t){function n(){Qi.writeFile(e,"",(e=>{if(e)return t(e);t()}))}Qi.stat(e,((r,u)=>{if(!r&&u.isFile())return t();const o=Zi.dirname(e);ts(o,((e,r)=>e?t(e):r?n():void es.mkdirs(o,(e=>{if(e)return t(e);n()}))))}))})),createFileSync:function(e){let t;try{t=Qi.statSync(e)}catch(e){}if(t&&t.isFile())return;const n=Zi.dirname(e);Qi.existsSync(n)||es.mkdirsSync(n),Qi.writeFileSync(e,"")}};const rs=yo.fromCallback,us=p.default,os=we,is=Io,ss=fi.pathExists;var cs={createLink:rs((function(e,t,n){function r(e,t){os.link(e,t,(e=>{if(e)return n(e);n(null)}))}ss(t,((u,o)=>u?n(u):o?n(null):void os.lstat(e,(u=>{if(u)return u.message=u.message.replace("lstat","ensureLink"),n(u);const o=us.dirname(t);ss(o,((u,i)=>u?n(u):i?r(e,t):void is.mkdirs(o,(u=>{if(u)return n(u);r(e,t)}))))}))))})),createLinkSync:function(e,t){if(os.existsSync(t))return;try{os.lstatSync(e)}catch(e){throw e.message=e.message.replace("lstat","ensureLink"),e}const n=us.dirname(t);return os.existsSync(n)||is.mkdirsSync(n),os.linkSync(e,t)}};const as=p.default,ls=we,fs=fi.pathExists;var ds={symlinkPaths:function(e,t,n){if(as.isAbsolute(e))return ls.lstat(e,(t=>t?(t.message=t.message.replace("lstat","ensureSymlink"),n(t)):n(null,{toCwd:e,toDst:e})));{const r=as.dirname(t),u=as.join(r,e);return fs(u,((t,o)=>t?n(t):o?n(null,{toCwd:u,toDst:e}):ls.lstat(e,(t=>t?(t.message=t.message.replace("lstat","ensureSymlink"),n(t)):n(null,{toCwd:e,toDst:as.relative(r,e)})))))}},symlinkPathsSync:function(e,t){let n;if(as.isAbsolute(e)){if(n=ls.existsSync(e),!n)throw new Error("absolute srcpath does not exist");return{toCwd:e,toDst:e}}{const r=as.dirname(t),u=as.join(r,e);if(n=ls.existsSync(u),n)return{toCwd:u,toDst:e};if(n=ls.existsSync(e),!n)throw new Error("relative srcpath does not exist");return{toCwd:e,toDst:as.relative(r,e)}}}};const Ds=we;var ps={symlinkType:function(e,t,n){if(n="function"==typeof t?t:n,t="function"!=typeof t&&t)return n(null,t);Ds.lstat(e,((e,r)=>{if(e)return n(null,"file");t=r&&r.isDirectory()?"dir":"file",n(null,t)}))},symlinkTypeSync:function(e,t){let n;if(t)return t;try{n=Ds.lstatSync(e)}catch(e){return"file"}return n&&n.isDirectory()?"dir":"file"}};const Es=yo.fromCallback,ms=p.default,hs=we,ys=Io.mkdirs,Cs=Io.mkdirsSync,Fs=ds.symlinkPaths,gs=ds.symlinkPathsSync,As=ps.symlinkType,vs=ps.symlinkTypeSync,Ss=fi.pathExists;var ws={createSymlink:Es((function(e,t,n,r){r="function"==typeof n?n:r,n="function"!=typeof n&&n,Ss(t,((u,o)=>u?r(u):o?r(null):void Fs(e,t,((u,o)=>{if(u)return r(u);e=o.toDst,As(o.toCwd,n,((n,u)=>{if(n)return r(n);const o=ms.dirname(t);Ss(o,((n,i)=>n?r(n):i?hs.symlink(e,t,u,r):void ys(o,(n=>{if(n)return r(n);hs.symlink(e,t,u,r)}))))}))}))))})),createSymlinkSync:function(e,t,n){if(hs.existsSync(t))return;const r=gs(e,t);e=r.toDst,n=vs(r.toCwd,n);const u=ms.dirname(t);return hs.existsSync(u)||Cs(u),hs.symlinkSync(e,t,n)}};var Os,bs={createFile:ns.createFile,createFileSync:ns.createFileSync,ensureFile:ns.createFile,ensureFileSync:ns.createFileSync,createLink:cs.createLink,createLinkSync:cs.createLinkSync,ensureLink:cs.createLink,ensureLinkSync:cs.createLinkSync,createSymlink:ws.createSymlink,createSymlinkSync:ws.createSymlinkSync,ensureSymlink:ws.createSymlink,ensureSymlinkSync:ws.createSymlinkSync};try{Os=we}catch(e){Os=D.default}function _s(e,t){var n,r="\n";return"object"==typeof t&&null!==t&&(t.spaces&&(n=t.spaces),t.EOL&&(r=t.EOL)),JSON.stringify(e,t?t.replacer:null,n).replace(/\n/g,r)+r}function Bs(e){return Buffer.isBuffer(e)&&(e=e.toString("utf8")),e=e.replace(/^\uFEFF/,"")}var Ps={readFile:function(e,t,n){null==n&&(n=t,t={}),"string"==typeof t&&(t={encoding:t});var r=(t=t||{}).fs||Os,u=!0;"throws"in t&&(u=t.throws),r.readFile(e,t,(function(r,o){if(r)return n(r);var i;o=Bs(o);try{i=JSON.parse(o,t?t.reviver:null)}catch(t){return u?(t.message=e+": "+t.message,n(t)):n(null,null)}n(null,i)}))},readFileSync:function(e,t){"string"==typeof(t=t||{})&&(t={encoding:t});var n=t.fs||Os,r=!0;"throws"in t&&(r=t.throws);try{var u=n.readFileSync(e,t);return u=Bs(u),JSON.parse(u,t.reviver)}catch(t){if(r)throw t.message=e+": "+t.message,t;return null}},writeFile:function(e,t,n,r){null==r&&(r=n,n={});var u=(n=n||{}).fs||Os,o="";try{o=_s(t,n)}catch(e){return void(r&&r(e,null))}u.writeFile(e,o,n,r)},writeFileSync:function(e,t,n){var r=(n=n||{}).fs||Os,u=_s(t,n);return r.writeFileSync(e,u,n)}},ks=Ps;const xs=yo.fromCallback,Ns=ks;var Is={readJson:xs(Ns.readFile),readJsonSync:Ns.readFileSync,writeJson:xs(Ns.writeFile),writeJsonSync:Ns.writeFileSync};const Ts=p.default,Rs=Io,Ms=fi.pathExists,Ls=Is;var js=function(e,t,n,r){"function"==typeof n&&(r=n,n={});const u=Ts.dirname(e);Ms(u,((o,i)=>o?r(o):i?Ls.writeJson(e,t,n,r):void Rs.mkdirs(u,(u=>{if(u)return r(u);Ls.writeJson(e,t,n,r)}))))};const $s=we,Hs=p.default,Js=Io,Gs=Is;var Vs=function(e,t,n){const r=Hs.dirname(e);$s.existsSync(r)||Js.mkdirsSync(r),Gs.writeJsonSync(e,t,n)};const Us=yo.fromCallback,Ws=Is;Ws.outputJson=Us(js),Ws.outputJsonSync=Vs,Ws.outputJSON=Ws.outputJson,Ws.outputJSONSync=Ws.outputJsonSync,Ws.writeJSON=Ws.writeJson,Ws.writeJSONSync=Ws.writeJsonSync,Ws.readJSON=Ws.readJson,Ws.readJSONSync=Ws.readJsonSync;var zs=Ws;const Ks=we,qs=p.default,Ys=ci.copySync,Xs=Ji.removeSync,Zs=Io.mkdirpSync,Qs=Zo;function ec(e,t,n){try{Ks.renameSync(e,t)}catch(r){if("EXDEV"!==r.code)throw r;return function(e,t,n){const r={overwrite:n,errorOnExist:!0};return Ys(e,t,r),Xs(e)}(e,t,n)}}var tc=function(e,t,n){const r=(n=n||{}).overwrite||n.clobber||!1,{srcStat:u}=Qs.checkPathsSync(e,t,"move");return Qs.checkParentPathsSync(e,u,t,"move"),Zs(qs.dirname(t)),function(e,t,n){if(n)return Xs(t),ec(e,t,n);if(Ks.existsSync(t))throw new Error("dest already exists.");return ec(e,t,n)}(e,t,r)},nc={moveSync:tc};const rc=we,uc=p.default,oc=bi.copy,ic=Ji.remove,sc=Io.mkdirp,cc=fi.pathExists,ac=Zo;function lc(e,t,n,r){rc.rename(e,t,(u=>u?"EXDEV"!==u.code?r(u):function(e,t,n,r){const u={overwrite:n,errorOnExist:!0};oc(e,t,u,(t=>t?r(t):ic(e,r)))}(e,t,n,r):r()))}var fc=function(e,t,n,r){"function"==typeof n&&(r=n,n={});const u=n.overwrite||n.clobber||!1;ac.checkPaths(e,t,"move",((n,o)=>{if(n)return r(n);const{srcStat:i}=o;ac.checkParentPaths(e,i,t,"move",(n=>{if(n)return r(n);sc(uc.dirname(t),(n=>n?r(n):function(e,t,n,r){if(n)return ic(t,(u=>u?r(u):lc(e,t,n,r)));cc(t,((u,o)=>u?r(u):o?r(new Error("dest already exists.")):lc(e,t,n,r)))}(e,t,u,r)))}))}))};var dc={move:(0,yo.fromCallback)(fc)};const Dc=yo.fromCallback,pc=we,Ec=p.default,mc=Io,hc=fi.pathExists;var yc={outputFile:Dc((function(e,t,n,r){"function"==typeof n&&(r=n,n="utf8");const u=Ec.dirname(e);hc(u,((o,i)=>o?r(o):i?pc.writeFile(e,t,n,r):void mc.mkdirs(u,(u=>{if(u)return r(u);pc.writeFile(e,t,n,r)}))))})),outputFileSync:function(e,...t){const n=Ec.dirname(e);if(pc.existsSync(n))return pc.writeFileSync(e,...t);mc.mkdirsSync(n),pc.writeFileSync(e,...t)}};!function(e){e.exports=Object.assign({},ho,ci,bi,Yi,bs,zs,Io,nc,dc,yc,fi,Ji);const t=D.default;Object.getOwnPropertyDescriptor(t,"promises")&&Object.defineProperty(e.exports,"promises",{get:()=>t.promises})}(mo);const Cc=Nr.exports("streamroller:fileNameFormatter"),Fc=p.default;const gc=Nr.exports("streamroller:fileNameParser"),Ac=nu.exports;const vc=Nr.exports("streamroller:moveAndMaybeCompressFile"),Sc=mo.exports,wc=v.default;var Oc=async(e,t,n)=>{if(n=function(e){const t={mode:parseInt("0600",8),compress:!1},n=Object.assign({},t,e);return vc(`_parseOption: moveAndMaybeCompressFile called with option=${JSON.stringify(n)}`),n}(n),e!==t){if(await Sc.pathExists(e))if(vc(`moveAndMaybeCompressFile: moving file from ${e} to ${t} ${n.compress?"with":"without"} compress`),n.compress)await new Promise(((r,u)=>{let o=!1;const i=Sc.createWriteStream(t,{mode:n.mode,flags:"wx"}).on("open",(()=>{o=!0;const t=Sc.createReadStream(e).on("open",(()=>{t.pipe(wc.createGzip()).pipe(i)})).on("error",(t=>{vc(`moveAndMaybeCompressFile: error reading ${e}`,t),i.destroy(t)}))})).on("finish",(()=>{vc(`moveAndMaybeCompressFile: finished compressing ${t}, deleting ${e}`),Sc.unlink(e).then(r).catch((t=>{vc(`moveAndMaybeCompressFile: error deleting ${e}, truncating instead`,t),Sc.truncate(e).then(r).catch((t=>{vc(`moveAndMaybeCompressFile: error truncating ${e}`,t),u(t)}))}))})).on("error",(e=>{o?(vc(`moveAndMaybeCompressFile: error writing ${t}, deleting`,e),Sc.unlink(t).then((()=>{u(e)})).catch((e=>{vc(`moveAndMaybeCompressFile: error deleting ${t}`,e),u(e)}))):(vc(`moveAndMaybeCompressFile: error creating ${t}`,e),u(e))}))})).catch((()=>{}));else{vc(`moveAndMaybeCompressFile: renaming ${e} to ${t}`);try{await Sc.move(e,t,{overwrite:!0})}catch(n){if(vc(`moveAndMaybeCompressFile: error renaming ${e} to ${t}`,n),"ENOENT"!==n.code){vc("moveAndMaybeCompressFile: trying copy+truncate instead");try{await Sc.copy(e,t,{overwrite:!0}),await Sc.truncate(e)}catch(e){vc("moveAndMaybeCompressFile: error copy+truncate",e)}}}}}else vc("moveAndMaybeCompressFile: source and target are the same, not doing anything")};const bc=Nr.exports("streamroller:RollingFileWriteStream"),_c=mo.exports,Bc=p.default,Pc=E.default,kc=()=>new Date,xc=nu.exports,{Writable:Nc}=C.default,Ic=({file:e,keepFileExt:t,needsIndex:n,alwaysIncludeDate:r,compress:u,fileNameSep:o})=>{let i=o||".";const s=Fc.join(e.dir,e.name),c=t=>t+e.ext,a=(e,t,r)=>!n&&r||!t?e:e+i+t,l=(e,t,n)=>(t>0||r)&&n?e+i+n:e,f=(e,t)=>t&&u?e+".gz":e,d=t?[l,a,c,f]:[c,l,a,f];return({date:e,index:t})=>(Cc(`_formatFileName: date=${e}, index=${t}`),d.reduce(((n,r)=>r(n,t,e)),s))},Tc=({file:e,keepFileExt:t,pattern:n,fileNameSep:r})=>{let u=r||".";const o="__NOT_MATCHING__";let i=[(e,t)=>e.endsWith(".gz")?(gc("it is gzipped"),t.isCompressed=!0,e.slice(0,-1*".gz".length)):e,t?t=>t.startsWith(e.name)&&t.endsWith(e.ext)?(gc("it starts and ends with the right things"),t.slice(e.name.length+1,-1*e.ext.length)):o:t=>t.startsWith(e.base)?(gc("it starts with the right things"),t.slice(e.base.length+1)):o,n?(e,t)=>{const r=e.split(u);let o=r[r.length-1];gc("items: ",r,", indexStr: ",o);let i=e;void 0!==o&&o.match(/^\d+$/)?(i=e.slice(0,-1*(o.length+1)),gc(`dateStr is ${i}`),n&&!i&&(i=o,o="0")):o="0";try{const r=Ac.parse(n,i,new Date(0,0));return Ac.asString(n,r)!==i?e:(t.index=parseInt(o,10),t.date=i,t.timestamp=r.getTime(),"")}catch(t){return gc(`Problem parsing ${i} as ${n}, error was: `,t),e}}:(e,t)=>e.match(/^\d+$/)?(gc("it has an index"),t.index=parseInt(e,10),""):e];return e=>{let t={filename:e,index:0,isCompressed:!1};return i.reduce(((e,n)=>n(e,t)),e)?null:t}},Rc=Oc;var Mc=class extends Nc{constructor(e,t){if(bc(`constructor: creating RollingFileWriteStream. path=${e}`),"string"!=typeof e||0===e.length)throw new Error(`Invalid filename: ${e}`);if(e.endsWith(Bc.sep))throw new Error(`Filename is a directory: ${e}`);0===e.indexOf(`~${Bc.sep}`)&&(e=e.replace("~",Pc.homedir())),super(t),this.options=this._parseOption(t),this.fileObject=Bc.parse(e),""===this.fileObject.dir&&(this.fileObject=Bc.parse(Bc.join(process.cwd(),e))),this.fileFormatter=Ic({file:this.fileObject,alwaysIncludeDate:this.options.alwaysIncludePattern,needsIndex:this.options.maxSize 0`)}else delete n.maxSize;if(n.numBackups||0===n.numBackups){if(n.numBackups<0)throw new Error(`options.numBackups (${n.numBackups}) should be >= 0`);if(n.numBackups>=Number.MAX_SAFE_INTEGER)throw new Error(`options.numBackups (${n.numBackups}) should be < Number.MAX_SAFE_INTEGER`);n.numToKeep=n.numBackups+1}else if(n.numToKeep<=0)throw new Error(`options.numToKeep (${n.numToKeep}) should be > 0`);return bc(`_parseOption: creating stream with option=${JSON.stringify(n)}`),n}_final(e){this.currentFileStream.end("",this.options.encoding,e)}_write(e,t,n){this._shouldRoll().then((()=>{bc(`_write: writing chunk. file=${this.currentFileStream.path} state=${JSON.stringify(this.state)} chunk=${e}`),this.currentFileStream.write(e,t,(t=>{this.state.currentSize+=e.length,n(t)}))}))}async _shouldRoll(){(this._dateChanged()||this._tooBig())&&(bc(`_shouldRoll: rolling because dateChanged? ${this._dateChanged()} or tooBig? ${this._tooBig()}`),await this._roll())}_dateChanged(){return this.state.currentDate&&this.state.currentDate!==xc(this.options.pattern,kc())}_tooBig(){return this.state.currentSize>=this.options.maxSize}_roll(){return bc("_roll: closing the current stream"),new Promise(((e,t)=>{this.currentFileStream.end("",this.options.encoding,(()=>{this._moveOldFiles().then(e).catch(t)}))}))}async _moveOldFiles(){const e=await this._getExistingFiles();for(let t=(this.state.currentDate?e.filter((e=>e.date===this.state.currentDate)):e).length;t>=0;t--){bc(`_moveOldFiles: i = ${t}`);const e=this.fileFormatter({date:this.state.currentDate,index:t}),n=this.fileFormatter({date:this.state.currentDate,index:t+1}),r={compress:this.options.compress&&0===t,mode:this.options.mode};await Rc(e,n,r)}this.state.currentSize=0,this.state.currentDate=this.state.currentDate?xc(this.options.pattern,kc()):null,bc(`_moveOldFiles: finished rolling files. state=${JSON.stringify(this.state)}`),this._renewWriteStream(),await new Promise(((e,t)=>{this.currentFileStream.write("","utf8",(()=>{this._clean().then(e).catch(t)}))}))}async _getExistingFiles(){const e=await _c.readdir(this.fileObject.dir).catch((()=>[]));bc(`_getExistingFiles: files=${e}`);const t=e.map((e=>this.fileNameParser(e))).filter((e=>e)),n=e=>(e.timestamp?e.timestamp:kc().getTime())-e.index;return t.sort(((e,t)=>n(e)-n(t))),t}_renewWriteStream(){const e=this.fileFormatter({date:this.state.currentDate,index:0}),t=e=>{try{return _c.mkdirSync(e,{recursive:!0})}catch(n){if("ENOENT"===n.code)return t(Bc.dirname(e)),t(e);if("EEXIST"!==n.code&&"EROFS"!==n.code)throw n;try{if(_c.statSync(e).isDirectory())return e;throw n}catch(e){throw n}}};t(this.fileObject.dir);const n={flags:this.options.flags,encoding:this.options.encoding,mode:this.options.mode};var r,u;_c.appendFileSync(e,"",(r={...n},u="flags",r["flag"]=r[u],delete r[u],r)),this.currentFileStream=_c.createWriteStream(e,n),this.currentFileStream.on("error",(e=>{this.emit("error",e)}))}async _clean(){const e=await this._getExistingFiles();if(bc(`_clean: numToKeep = ${this.options.numToKeep}, existingFiles = ${e.length}`),bc("_clean: existing files are: ",e),this._tooManyFiles(e.length)){const n=e.slice(0,e.length-this.options.numToKeep).map((e=>Bc.format({dir:this.fileObject.dir,base:e.filename})));await(t=n,bc(`deleteFiles: files to delete: ${t}`),Promise.all(t.map((e=>_c.unlink(e).catch((t=>{bc(`deleteFiles: error when unlinking ${e}, ignoring. Error was ${t}`)}))))))}var t}_tooManyFiles(e){return this.options.numToKeep>0&&e>this.options.numToKeep}};const Lc=Mc;var jc=class extends Lc{constructor(e,t,n,r){r||(r={}),t&&(r.maxSize=t),r.numBackups||0===r.numBackups||(n||0===n||(n=1),r.numBackups=n),super(e,r),this.backups=r.numBackups,this.size=this.options.maxSize}get theStream(){return this.currentFileStream}};const $c=Mc;var Hc={RollingFileWriteStream:Mc,RollingFileStream:jc,DateRollingFileStream:class extends $c{constructor(e,t,n){t&&"object"==typeof t&&(n=t,t=null),n||(n={}),t||(t="yyyy-MM-dd"),n.pattern=t,n.numBackups||0===n.numBackups?n.daysToKeep=n.numBackups:(n.daysToKeep||0===n.daysToKeep?process.emitWarning("options.daysToKeep is deprecated due to the confusion it causes when used together with file size rolling. Please use options.numBackups instead.","DeprecationWarning","streamroller-DEP0001"):n.daysToKeep=1,n.numBackups=n.daysToKeep),super(e,n),this.mode=this.options.mode}get theStream(){return this.currentFileStream}}};const Jc=Nr.exports("log4js:file"),Gc=p.default,Vc=Hc,Uc=E.default.EOL;let Wc=!1;const zc=new Set;function Kc(){zc.forEach((e=>{e.sighupHandler()}))}function qc(e,t,n,r){const u=new Vc.RollingFileStream(e,t,n,r);return u.on("error",(t=>{console.error("log4js.fileAppender - Writing to file %s, error happened ",e,t)})),u.on("drain",(()=>{process.emit("log4js:pause",!1)})),u}Eo.configure=function(e,t){let n=t.basicLayout;return e.layout&&(n=t.layout(e.layout.type,e.layout)),e.mode=e.mode||384,function(e,t,n,r,u,o){e=Gc.normalize(e),Jc("Creating file appender (",e,", ",n,", ",r=r||0===r?r:5,", ",u,", ",o,")");let i=qc(e,n,r,u);const s=function(e){if(i.writable){if(!0===u.removeColor){const t=/\x1b[[0-9;]*m/g;e.data=e.data.map((e=>"string"==typeof e?e.replace(t,""):e))}i.write(t(e,o)+Uc,"utf8")||process.emit("log4js:pause",!0)}};return s.reopen=function(){i.end((()=>{i=qc(e,n,r,u)}))},s.sighupHandler=function(){Jc("SIGHUP handler called."),s.reopen()},s.shutdown=function(e){zc.delete(s),0===zc.size&&Wc&&(process.removeListener("SIGHUP",Kc),Wc=!1),i.end("","utf-8",e)},zc.add(s),Wc||(process.on("SIGHUP",Kc),Wc=!0),s}(e.filename,n,e.maxLogSize,e.backups,e,e.timezoneOffset)};var Yc={};const Xc=Hc,Zc=E.default.EOL;function Qc(e,t,n,r,u){r.maxSize=r.maxLogSize;const o=function(e,t,n){const r=new Xc.DateRollingFileStream(e,t,n);return r.on("error",(t=>{console.error("log4js.dateFileAppender - Writing to file %s, error happened ",e,t)})),r.on("drain",(()=>{process.emit("log4js:pause",!1)})),r}(e,t,r),i=function(e){o.writable&&(o.write(n(e,u)+Zc,"utf8")||process.emit("log4js:pause",!0))};return i.shutdown=function(e){o.end("","utf-8",e)},i}Yc.configure=function(e,t){let n=t.basicLayout;return e.layout&&(n=t.layout(e.layout.type,e.layout)),e.alwaysIncludePattern||(e.alwaysIncludePattern=!1),e.mode=e.mode||384,Qc(e.filename,e.pattern,n,e,e.timezoneOffset)};var ea={};const ta=Nr.exports("log4js:fileSync"),na=p.default,ra=D.default,ua=E.default.EOL||"\n";function oa(e,t){if(ra.existsSync(e))return;const n=ra.openSync(e,t.flags,t.mode);ra.closeSync(n)}class ia{constructor(e,t,n,r){ta("In RollingFileStream"),function(){if(!e||!t||t<=0)throw new Error("You must specify a filename and file size")}(),this.filename=e,this.size=t,this.backups=n,this.options=r,this.currentSize=0,this.currentSize=function(e){let t=0;try{t=ra.statSync(e).size}catch(t){oa(e,r)}return t}(this.filename)}shouldRoll(){return ta("should roll with current size %d, and max size %d",this.currentSize,this.size),this.currentSize>=this.size}roll(e){const t=this,n=new RegExp(`^${na.basename(e)}`);function r(e){return n.test(e)}function u(t){return parseInt(t.substring(`${na.basename(e)}.`.length),10)||0}function o(e,t){return u(e)>u(t)?1:u(e) ${e}.${r+1}`),ra.renameSync(na.join(na.dirname(e),n),`${e}.${r+1}`)}}ta("Rolling, rolling, rolling"),ta("Renaming the old files"),ra.readdirSync(na.dirname(e)).filter(r).sort(o).reverse().forEach(i)}write(e,t){const n=this;ta("in write"),this.shouldRoll()&&(this.currentSize=0,this.roll(this.filename)),ta("writing the chunk to the file"),n.currentSize+=e.length,ra.appendFileSync(n.filename,e)}}ea.configure=function(e,t){let n=t.basicLayout;e.layout&&(n=t.layout(e.layout.type,e.layout));const r={flags:e.flags||"a",encoding:e.encoding||"utf8",mode:e.mode||384};return function(e,t,n,r,u,o){ta("fileSync appender created");const i=function(e,t,n){let r;var u;return t?r=new ia(e,t,n,o):(oa(u=e,o),r={write(e){ra.appendFileSync(u,e)}}),r}(e=na.normalize(e),n,r=r||0===r?r:5);return e=>{i.write(t(e,u)+ua)}}(e.filename,n,e.maxLogSize,e.backups,e.timezoneOffset,r)};var sa={};const ca=Nr.exports("log4js:tcp"),aa=S.default;sa.configure=function(e,t){ca(`configure with config = ${e}`);let n=function(e){return e.serialise()};return e.layout&&(n=t.layout(e.layout.type,e.layout)),function(e,t){let n=!1;const r=[];let u,o=3,i="__LOG4JS__";function s(e){ca("Writing log event to socket"),n=u.write(`${t(e)}${i}`,"utf8")}function c(){let e;for(ca("emptying buffer");e=r.shift();)s(e)}function a(e){n?s(e):(ca("buffering log event because it cannot write at the moment"),r.push(e))}return function t(){ca(`appender creating socket to ${e.host||"localhost"}:${e.port||5e3}`),i=`${e.endMsg||"__LOG4JS__"}`,u=aa.createConnection(e.port||5e3,e.host||"localhost"),u.on("connect",(()=>{ca("socket connected"),c(),n=!0})),u.on("drain",(()=>{ca("drain event received, emptying buffer"),n=!0,c()})),u.on("timeout",u.end.bind(u)),u.on("error",(e=>{ca("connection error",e),n=!1,c()})),u.on("close",t)}(),a.shutdown=function(e){ca("shutdown called"),r.length&&o?(ca("buffer has items, waiting 100ms to empty"),o-=1,setTimeout((()=>{a.shutdown(e)}),100)):(u.removeAllListeners("close"),u.end(e))},a}(e,n)};const la=p.default,fa=Nr.exports("log4js:appenders"),da=tu,Da=eo,pa=gu,Ea=hu,ma=to,ha=new Map;ha.set("console",oo),ha.set("stdout",so),ha.set("stderr",co),ha.set("logLevelFilter",ao),ha.set("categoryFilter",lo),ha.set("noLogFilter",Do),ha.set("file",Eo),ha.set("dateFile",Yc),ha.set("fileSync",ea),ha.set("tcp",sa);const ya=new Map,Ca=(e,t)=>{fa("Loading module from ",e);try{return require(e)}catch(n){return void da.throwExceptionIf(t,"MODULE_NOT_FOUND"!==n.code,`appender "${e}" could not be loaded (error was: ${n})`)}},Fa=new Set,ga=(e,t)=>{if(ya.has(e))return ya.get(e);if(!t.appenders[e])return!1;if(Fa.has(e))throw new Error(`Dependency loop detected for appender ${e}.`);Fa.add(e),fa(`Creating appender ${e}`);const n=Aa(e,t);return Fa.delete(e),ya.set(e,n),n},Aa=(e,t)=>{const n=t.appenders[e],r=n.type.configure?n.type:((e,t)=>ha.get(e)||Ca(`./${e}`,t)||Ca(e,t)||require.main&&Ca(la.join(la.dirname(require.main.filename),e),t)||Ca(la.join(process.cwd(),e),t))(n.type,t);return da.throwExceptionIf(t,da.not(r),`appender "${e}" is not valid (type "${n.type}" could not be found)`),r.appender&&fa(`DEPRECATION: Appender ${n.type} exports an appender function.`),r.shutdown&&fa(`DEPRECATION: Appender ${n.type} exports a shutdown function.`),fa(`${e}: clustering.isMaster ? ${Da.isMaster()}`),fa(`${e}: appenderModule is ${F.default.inspect(r)}`),Da.onlyOnMaster((()=>(fa(`calling appenderModule.configure for ${e} / ${n.type}`),r.configure(ma.modifyConfig(n),Ea,(e=>ga(e,t)),pa))),(()=>{}))},va=e=>{ya.clear(),Fa.clear();const t=[];Object.values(e.categories).forEach((e=>{t.push(...e.appenders)})),Object.keys(e.appenders).forEach((n=>{(t.includes(n)||"tcp-server"===e.appenders[n].type)&&ga(n,e)}))},Sa=()=>{va({appenders:{out:{type:"stdout"}},categories:{default:{appenders:["out"],level:"trace"}}})};Sa(),da.addListener((e=>{da.throwExceptionIf(e,da.not(da.anObject(e.appenders)),'must have a property "appenders" of type object.');const t=Object.keys(e.appenders);da.throwExceptionIf(e,da.not(t.length),"must define at least one appender."),t.forEach((t=>{da.throwExceptionIf(e,da.not(e.appenders[t].type),`appender "${t}" is not valid (must be an object with property "type")`)}))})),da.addListener(va),Au.exports=ya,Au.exports.init=Sa;var wa={exports:{}};!function(e){const t=Nr.exports("log4js:categories"),n=tu,r=gu,u=Au.exports,o=new Map;function i(e,t,n){if(!1===t.inherit)return;const r=n.lastIndexOf(".");if(r<0)return;const u=n.substring(0,r);let o=e.categories[u];o||(o={inherit:!0,appenders:[]}),i(e,o,u),!e.categories[u]&&o.appenders&&o.appenders.length&&o.level&&(e.categories[u]=o),t.appenders=t.appenders||[],t.level=t.level||o.level,o.appenders.forEach((e=>{t.appenders.includes(e)||t.appenders.push(e)})),t.parent=o}function s(e){if(!e.categories)return;Object.keys(e.categories).forEach((t=>{const n=e.categories[t];i(e,n,t)}))}n.addPreProcessingListener((e=>s(e))),n.addListener((e=>{n.throwExceptionIf(e,n.not(n.anObject(e.categories)),'must have a property "categories" of type object.');const t=Object.keys(e.categories);n.throwExceptionIf(e,n.not(t.length),"must define at least one category."),t.forEach((t=>{const o=e.categories[t];n.throwExceptionIf(e,[n.not(o.appenders),n.not(o.level)],`category "${t}" is not valid (must be an object with properties "appenders" and "level")`),n.throwExceptionIf(e,n.not(Array.isArray(o.appenders)),`category "${t}" is not valid (appenders must be an array of appender names)`),n.throwExceptionIf(e,n.not(o.appenders.length),`category "${t}" is not valid (appenders must contain at least one appender name)`),Object.prototype.hasOwnProperty.call(o,"enableCallStack")&&n.throwExceptionIf(e,"boolean"!=typeof o.enableCallStack,`category "${t}" is not valid (enableCallStack must be boolean type)`),o.appenders.forEach((r=>{n.throwExceptionIf(e,n.not(u.get(r)),`category "${t}" is not valid (appender "${r}" is not defined)`)})),n.throwExceptionIf(e,n.not(r.getLevel(o.level)),`category "${t}" is not valid (level "${o.level}" not recognised; valid levels are ${r.levels.join(", ")})`)})),n.throwExceptionIf(e,n.not(e.categories.default),'must define a "default" category.')}));const c=e=>{o.clear();Object.keys(e.categories).forEach((n=>{const i=e.categories[n],s=[];i.appenders.forEach((e=>{s.push(u.get(e)),t(`Creating category ${n}`),o.set(n,{appenders:s,level:r.getLevel(i.level),enableCallStack:i.enableCallStack||!1})}))}))},a=()=>{c({categories:{default:{appenders:["out"],level:"OFF"}}})};a(),n.addListener(c);const l=e=>(t(`configForCategory: searching for config for ${e}`),o.has(e)?(t(`configForCategory: ${e} exists in config, returning it`),o.get(e)):e.indexOf(".")>0?(t(`configForCategory: ${e} has hierarchy, searching for parents`),l(e.substring(0,e.lastIndexOf(".")))):(t("configForCategory: returning config for default category"),l("default")));e.exports=o,e.exports=Object.assign(e.exports,{appendersForCategory:e=>l(e).appenders,getLevelForCategory:e=>l(e).level,setLevelForCategory:(e,n)=>{let r=o.get(e);if(t(`setLevelForCategory: found ${r} for ${e}`),!r){const n=l(e);t(`setLevelForCategory: no config found for category, found ${n} for parents of ${e}`),r={appenders:n.appenders}}r.level=n,o.set(e,r)},getEnableCallStackForCategory:e=>!0===l(e).enableCallStack,setEnableCallStackForCategory:(e,t)=>{l(e).enableCallStack=t},init:a})}(wa);const Oa=Nr.exports("log4js:logger"),ba=Hu,_a=gu,Ba=eo,Pa=wa.exports,ka=tu,xa=/at (?:(.+)\s+\()?(?:(.+?):(\d+)(?::(\d+))?|([^)]+))\)?/;function Na(e,t=4){const n=e.stack.split("\n").slice(t),r=xa.exec(n[0]);return r&&6===r.length?{functionName:r[1],fileName:r[2],lineNumber:parseInt(r[3],10),columnNumber:parseInt(r[4],10),callStack:n.join("\n")}:null}class Ia{constructor(e){if(!e)throw new Error("No category provided.");this.category=e,this.context={},this.parseCallStack=Na,Oa(`Logger created (${this.category}, ${this.level})`)}get level(){return _a.getLevel(Pa.getLevelForCategory(this.category),_a.TRACE)}set level(e){Pa.setLevelForCategory(this.category,_a.getLevel(e,this.level))}get useCallStack(){return Pa.getEnableCallStackForCategory(this.category)}set useCallStack(e){Pa.setEnableCallStackForCategory(this.category,!0===e)}log(e,...t){let n=_a.getLevel(e);n||(this._log(_a.WARN,"log4js:logger.log: invalid value for log-level as first parameter given: ",e),n=_a.INFO),this.isLevelEnabled(n)&&this._log(n,t)}isLevelEnabled(e){return this.level.isLessThanOrEqualTo(e)}_log(e,t){Oa(`sending log data (${e}) to appenders`);const n=new ba(this.category,e,t,this.context,this.useCallStack&&this.parseCallStack(new Error));Ba.send(n)}addContext(e,t){this.context[e]=t}removeContext(e){delete this.context[e]}clearContext(){this.context={}}setParseCallStackFunction(e){this.parseCallStack=e}}function Ta(e){const t=_a.getLevel(e),n=t.toString().toLowerCase().replace(/_([a-z])/g,(e=>e[1].toUpperCase())),r=n[0].toUpperCase()+n.slice(1);Ia.prototype[`is${r}Enabled`]=function(){return this.isLevelEnabled(t)},Ia.prototype[n]=function(...e){this.log(t,...e)}}_a.levels.forEach(Ta),ka.addListener((()=>{_a.levels.forEach(Ta)}));var Ra=Ia;const Ma=gu;function La(e){return e.originalUrl||e.url}function ja(e,t){for(let n=0;ne.source?e.source:e));t=new RegExp(n.join("|"))}return t}(t.nolog);return(e,i,s)=>{if(e._logging)return s();if(o&&o.test(e.originalUrl))return s();if(n.isLevelEnabled(r)||"auto"===t.level){const o=new Date,{writeHead:s}=i;e._logging=!0,i.writeHead=(e,t)=>{i.writeHead=s,i.writeHead(e,t),i.__statusCode=e,i.__headers=t||{}},i.on("finish",(()=>{i.responseTime=new Date-o,i.statusCode&&"auto"===t.level&&(r=Ma.INFO,i.statusCode>=300&&(r=Ma.WARN),i.statusCode>=400&&(r=Ma.ERROR)),r=function(e,t,n){let r=t;if(n){const t=n.find((t=>{let n=!1;return n=t.from&&t.to?e>=t.from&&e<=t.to:-1!==t.codes.indexOf(e),n}));t&&(r=Ma.getLevel(t.level,r))}return r}(i.statusCode,r,t.statusRules);const s=function(e,t,n){const r=[];return r.push({token:":url",replacement:La(e)}),r.push({token:":protocol",replacement:e.protocol}),r.push({token:":hostname",replacement:e.hostname}),r.push({token:":method",replacement:e.method}),r.push({token:":status",replacement:t.__statusCode||t.statusCode}),r.push({token:":response-time",replacement:t.responseTime}),r.push({token:":date",replacement:(new Date).toUTCString()}),r.push({token:":referrer",replacement:e.headers.referer||e.headers.referrer||""}),r.push({token:":http-version",replacement:`${e.httpVersionMajor}.${e.httpVersionMinor}`}),r.push({token:":remote-addr",replacement:e.headers["x-forwarded-for"]||e.ip||e._remoteAddress||e.socket&&(e.socket.remoteAddress||e.socket.socket&&e.socket.socket.remoteAddress)}),r.push({token:":user-agent",replacement:e.headers["user-agent"]}),r.push({token:":content-length",replacement:t.getHeader("content-length")||t.__headers&&t.__headers["Content-Length"]||"-"}),r.push({token:/:req\[([^\]]+)]/g,replacement:(t,n)=>e.headers[n.toLowerCase()]}),r.push({token:/:res\[([^\]]+)]/g,replacement:(e,n)=>t.getHeader(n.toLowerCase())||t.__headers&&t.__headers[n]}),(e=>{const t=e.concat();for(let e=0;eja(e,s)));t&&n.log(r,t)}else n.log(r,ja(u,s));t.context&&n.removeContext("res")}))}return s()}},nl=Va;let rl=!1;function ul(e){if(!rl)return;Ua("Received log event ",e);Za.appendersForCategory(e.categoryName).forEach((t=>{t(e)}))}function ol(e){rl&&il();let t=e;return"string"==typeof t&&(t=function(e){Ua(`Loading configuration from ${e}`);try{return JSON.parse(Wa.readFileSync(e,"utf8"))}catch(t){throw new Error(`Problem reading config from file "${e}". Error was ${t.message}`,t)}}(e)),Ua(`Configuration is ${t}`),Ka.configure(za(t)),el.onMessage(ul),rl=!0,sl}function il(e){Ua("Shutdown called. Disabling all log writing."),rl=!1;const t=Array.from(Xa.values());Xa.init(),Za.init();const n=t.reduceRight(((e,t)=>t.shutdown?e+1:e),0);if(0===n)return Ua("No appenders with shutdown functions found."),void 0!==e&&e();let r,u=0;function o(t){r=r||t,u+=1,Ua(`Appender shutdowns complete: ${u} / ${n}`),u>=n&&(Ua("All shutdown functions completed."),e&&e(r))}return Ua(`Found ${n} appenders with shutdown functions.`),t.filter((e=>e.shutdown)).forEach((e=>e.shutdown(o))),null}const sl={getLogger:function(e){return rl||ol(process.env.LOG4JS_CONFIG||{appenders:{out:{type:"stdout"}},categories:{default:{appenders:["out"],level:"OFF"}}}),new Qa(e||"default")},configure:ol,shutdown:il,connectLogger:tl,levels:Ya,addLayout:qa.addLayout,recording:function(){return nl}};var cl=sl,al={};Object.defineProperty(al,"__esModule",{value:!0}),al.levelMap=al.getLevel=al.setCategoriesLevel=al.getConfiguration=al.setConfiguration=void 0;const ll=cl;let fl={appenders:{debug:{type:"stdout",layout:{type:"pattern",pattern:"[%d] > hvigor %p %c %[%m%]"}},info:{type:"stdout",layout:{type:"pattern",pattern:"[%d] > hvigor %[%m%]"}},"no-pattern-info":{type:"stdout",layout:{type:"pattern",pattern:"%m"}},wrong:{type:"stderr",layout:{type:"pattern",pattern:"[%d] > hvigor %[%p: %m%]"}},"just-debug":{type:"logLevelFilter",appender:"debug",level:"debug",maxLevel:"debug"},"just-info":{type:"logLevelFilter",appender:"info",level:"info",maxLevel:"info"},"just-wrong":{type:"logLevelFilter",appender:"wrong",level:"warn",maxLevel:"error"}},categories:{default:{appenders:["just-debug","just-info","just-wrong"],level:"debug"},"no-pattern-info":{appenders:["no-pattern-info"],level:"info"}}};al.setConfiguration=e=>{fl=e};al.getConfiguration=()=>fl;let dl=ll.levels.DEBUG;al.setCategoriesLevel=(e,t)=>{dl=e;const n=fl.categories;for(const r in n)(null==t?void 0:t.includes(r))||Object.prototype.hasOwnProperty.call(n,r)&&(n[r].level=e.levelStr)};al.getLevel=()=>dl,al.levelMap=new Map([["ALL",ll.levels.ALL],["MARK",ll.levels.MARK],["TRACE",ll.levels.TRACE],["DEBUG",ll.levels.DEBUG],["INFO",ll.levels.INFO],["WARN",ll.levels.WARN],["ERROR",ll.levels.ERROR],["FATAL",ll.levels.FATAL],["OFF",ll.levels.OFF]]);var Dl=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),pl=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),El=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)"default"!==n&&Object.prototype.hasOwnProperty.call(e,n)&&Dl(t,e,n);return pl(t,e),t};Object.defineProperty(xr,"__esModule",{value:!0}),xr.evaluateLogLevel=xr.HvigorLogger=void 0;const ml=El(cl),hl=cl,yl=El(F.default),Cl=al;class Fl{constructor(e){ml.configure((0,Cl.getConfiguration)()),this._logger=ml.getLogger(e),this._logger.level=(0,Cl.getLevel)()}static getLogger(e){return new Fl(e)}log(e,...t){this._logger.log(e,...t)}debug(e,...t){this._logger.debug(e,...t)}info(e,...t){this._logger.info(e,...t)}warn(e,...t){void 0!==e&&""!==e&&this._logger.warn(e,...t)}error(e,...t){this._logger.error(e,...t)}_printTaskExecuteInfo(e,t){this.info(`Finished :${e}... after ${t}`)}_printFailedTaskInfo(e){this.error(`Failed :${e}... `)}_printDisabledTaskInfo(e){this.info(`Disabled :${e}... `)}_printUpToDateTaskInfo(e){this.info(`UP-TO-DATE :${e}... `)}errorMessageExit(e,...t){throw new Error(yl.format(e,...t))}errorExit(e,t,...n){t&&this._logger.error(t,n),this._logger.error(e.stack)}setLevel(e,t){(0,Cl.setCategoriesLevel)(e,t),ml.shutdown(),ml.configure((0,Cl.getConfiguration)())}getLevel(){return this._logger.level}configure(e){const t=(0,Cl.getConfiguration)(),n={appenders:{...t.appenders,...e.appenders},categories:{...t.categories,...e.categories}};(0,Cl.setConfiguration)(n),ml.shutdown(),ml.configure(n)}}xr.HvigorLogger=Fl,xr.evaluateLogLevel=function(e,t){t.debug?e.setLevel(hl.levels.DEBUG):t.warn?e.setLevel(hl.levels.WARN):t.error?e.setLevel(hl.levels.ERROR):e.setLevel(hl.levels.INFO)};var gl=w&&w.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(X,"__esModule",{value:!0}),X.parseJsonText=X.parseJsonFile=void 0;const Al=Z,vl=gl(kr),Sl=gl(p.default),wl=gl(E.default),Ol=xr.HvigorLogger.getLogger("parse-json-util");var bl;!function(e){e[e.Char=0]="Char",e[e.EOF=1]="EOF",e[e.Identifier=2]="Identifier"}(bl||(bl={}));let _l,Bl,Pl,kl,xl,Nl,Il="start",Tl=[],Rl=0,Ml=1,Ll=0,jl=!1,$l="default",Hl="'",Jl=1;function Gl(e,t=!1){Bl=String(e),Il="start",Tl=[],Rl=0,Ml=1,Ll=0,kl=void 0,jl=t;do{_l=Vl(),Xl[Il]()}while("eof"!==_l.type);return kl}function Vl(){for($l="default",xl="",Hl="'",Jl=1;;){Nl=Ul();const e=zl[$l]();if(e)return e}}function Ul(){if(Bl[Rl])return String.fromCodePoint(Bl.codePointAt(Rl))}function Wl(){const e=Ul();return"\n"===e?(Ml++,Ll=0):e?Ll+=e.length:Ll++,e&&(Rl+=e.length),e}X.parseJsonFile=function(e,t=!1,n="utf-8"){const r=vl.default.readFileSync(Sl.default.resolve(e),{encoding:n});try{return Gl(r,t)}catch(t){if(t instanceof SyntaxError){const n=t.message.split("at");2===n.length&&Ol.errorMessageExit(`${n[0].trim()}${wl.default.EOL}\t at ${e}:${n[1].trim()}`)}Ol.errorMessageExit(`${e} is not in valid JSON/JSON5 format.`)}},X.parseJsonText=Gl;const zl={default(){switch(Nl){case"/":return Wl(),void($l="comment");case void 0:return Wl(),Kl("eof")}if(!Al.JudgeUtil.isIgnoreChar(Nl)&&!Al.JudgeUtil.isSpaceSeparator(Nl))return zl[Il]();Wl()},start(){$l="value"},beforePropertyName(){switch(Nl){case"$":case"_":return xl=Wl(),void($l="identifierName");case"\\":return Wl(),void($l="identifierNameStartEscape");case"}":return Kl("punctuator",Wl());case'"':case"'":return Hl=Nl,Wl(),void($l="string")}if(Al.JudgeUtil.isIdStartChar(Nl))return xl+=Wl(),void($l="identifierName");throw tf(bl.Char,Wl())},afterPropertyName(){if(":"===Nl)return Kl("punctuator",Wl());throw tf(bl.Char,Wl())},beforePropertyValue(){$l="value"},afterPropertyValue(){switch(Nl){case",":case"}":return Kl("punctuator",Wl())}throw tf(bl.Char,Wl())},beforeArrayValue(){if("]"===Nl)return Kl("punctuator",Wl());$l="value"},afterArrayValue(){switch(Nl){case",":case"]":return Kl("punctuator",Wl())}throw tf(bl.Char,Wl())},end(){throw tf(bl.Char,Wl())},comment(){switch(Nl){case"*":return Wl(),void($l="multiLineComment");case"/":return Wl(),void($l="singleLineComment")}throw tf(bl.Char,Wl())},multiLineComment(){switch(Nl){case"*":return Wl(),void($l="multiLineCommentAsterisk");case void 0:throw tf(bl.Char,Wl())}Wl()},multiLineCommentAsterisk(){switch(Nl){case"*":return void Wl();case"/":return Wl(),void($l="default");case void 0:throw tf(bl.Char,Wl())}Wl(),$l="multiLineComment"},singleLineComment(){switch(Nl){case"\n":case"\r":case"\u2028":case"\u2029":return Wl(),void($l="default");case void 0:return Wl(),Kl("eof")}Wl()},value(){switch(Nl){case"{":case"[":return Kl("punctuator",Wl());case"n":return Wl(),ql("ull"),Kl("null",null);case"t":return Wl(),ql("rue"),Kl("boolean",!0);case"f":return Wl(),ql("alse"),Kl("boolean",!1);case"-":case"+":return"-"===Wl()&&(Jl=-1),void($l="numerical");case".":case"0":case"I":case"N":return void($l="numerical");case'"':case"'":return Hl=Nl,Wl(),xl="",void($l="string")}if(void 0===Nl||!Al.JudgeUtil.isDigitWithoutZero(Nl))throw tf(bl.Char,Wl());$l="numerical"},numerical(){switch(Nl){case".":return xl=Wl(),void($l="decimalPointLeading");case"0":return xl=Wl(),void($l="zero");case"I":return Wl(),ql("nfinity"),Kl("numeric",Jl*(1/0));case"N":return Wl(),ql("aN"),Kl("numeric",NaN)}if(void 0!==Nl&&Al.JudgeUtil.isDigitWithoutZero(Nl))return xl=Wl(),void($l="decimalInteger");throw tf(bl.Char,Wl())},zero(){switch(Nl){case".":case"e":case"E":return void($l="decimal");case"x":case"X":return xl+=Wl(),void($l="hexadecimal")}return Kl("numeric",0)},decimalInteger(){switch(Nl){case".":case"e":case"E":return void($l="decimal")}if(!Al.JudgeUtil.isDigit(Nl))return Kl("numeric",Jl*Number(xl));xl+=Wl()},decimal(){switch(Nl){case".":xl+=Wl(),$l="decimalFraction";break;case"e":case"E":xl+=Wl(),$l="decimalExponent"}},decimalPointLeading(){if(Al.JudgeUtil.isDigit(Nl))return xl+=Wl(),void($l="decimalFraction");throw tf(bl.Char,Wl())},decimalFraction(){switch(Nl){case"e":case"E":return xl+=Wl(),void($l="decimalExponent")}if(!Al.JudgeUtil.isDigit(Nl))return Kl("numeric",Jl*Number(xl));xl+=Wl()},decimalExponent(){switch(Nl){case"+":case"-":return xl+=Wl(),void($l="decimalExponentSign")}if(Al.JudgeUtil.isDigit(Nl))return xl+=Wl(),void($l="decimalExponentInteger");throw tf(bl.Char,Wl())},decimalExponentSign(){if(Al.JudgeUtil.isDigit(Nl))return xl+=Wl(),void($l="decimalExponentInteger");throw tf(bl.Char,Wl())},decimalExponentInteger(){if(!Al.JudgeUtil.isDigit(Nl))return Kl("numeric",Jl*Number(xl));xl+=Wl()},hexadecimal(){if(Al.JudgeUtil.isHexDigit(Nl))return xl+=Wl(),void($l="hexadecimalInteger");throw tf(bl.Char,Wl())},hexadecimalInteger(){if(!Al.JudgeUtil.isHexDigit(Nl))return Kl("numeric",Jl*Number(xl));xl+=Wl()},identifierNameStartEscape(){if("u"!==Nl)throw tf(bl.Char,Wl());Wl();const e=Yl();switch(e){case"$":case"_":break;default:if(!Al.JudgeUtil.isIdStartChar(e))throw tf(bl.Identifier)}xl+=e,$l="identifierName"},identifierName(){switch(Nl){case"$":case"_":case"":case"":return void(xl+=Wl());case"\\":return Wl(),void($l="identifierNameEscape")}if(!Al.JudgeUtil.isIdContinueChar(Nl))return Kl("identifier",xl);xl+=Wl()},identifierNameEscape(){if("u"!==Nl)throw tf(bl.Char,Wl());Wl();const e=Yl();switch(e){case"$":case"_":case"":case"":break;default:if(!Al.JudgeUtil.isIdContinueChar(e))throw tf(bl.Identifier)}xl+=e,$l="identifierName"},string(){switch(Nl){case"\\":return Wl(),void(xl+=function(){const e=Ul(),t=function(){switch(Ul()){case"b":return Wl(),"\b";case"f":return Wl(),"\f";case"n":return Wl(),"\n";case"r":return Wl(),"\r";case"t":return Wl(),"\t";case"v":return Wl(),"\v"}return}();if(t)return t;switch(e){case"0":if(Wl(),Al.JudgeUtil.isDigit(Ul()))throw tf(bl.Char,Wl());return"\0";case"x":return Wl(),function(){let e="",t=Ul();if(!Al.JudgeUtil.isHexDigit(t))throw tf(bl.Char,Wl());if(e+=Wl(),t=Ul(),!Al.JudgeUtil.isHexDigit(t))throw tf(bl.Char,Wl());return e+=Wl(),String.fromCodePoint(parseInt(e,16))}();case"u":return Wl(),Yl();case"\n":case"\u2028":case"\u2029":return Wl(),"";case"\r":return Wl(),"\n"===Ul()&&Wl(),""}if(void 0===e||Al.JudgeUtil.isDigitWithoutZero(e))throw tf(bl.Char,Wl());return Wl()}());case'"':case"'":if(Nl===Hl){const e=Kl("string",xl);return Wl(),e}return void(xl+=Wl());case"\n":case"\r":case void 0:throw tf(bl.Char,Wl());case"\u2028":case"\u2029":!function(e){Ol.warn(`JSON5: '${ef(e)}' in strings is not valid ECMAScript; consider escaping.`)}(Nl)}xl+=Wl()}};function Kl(e,t){return{type:e,value:t,line:Ml,column:Ll}}function ql(e){for(const t of e){if(Ul()!==t)throw tf(bl.Char,Wl());Wl()}}function Yl(){let e="",t=4;for(;t-- >0;){const t=Ul();if(!Al.JudgeUtil.isHexDigit(t))throw tf(bl.Char,Wl());e+=Wl()}return String.fromCodePoint(parseInt(e,16))}const Xl={start(){if("eof"===_l.type)throw tf(bl.EOF);Zl()},beforePropertyName(){switch(_l.type){case"identifier":case"string":return Pl=_l.value,void(Il="afterPropertyName");case"punctuator":return void Ql();case"eof":throw tf(bl.EOF)}},afterPropertyName(){if("eof"===_l.type)throw tf(bl.EOF);Il="beforePropertyValue"},beforePropertyValue(){if("eof"===_l.type)throw tf(bl.EOF);Zl()},afterPropertyValue(){if("eof"===_l.type)throw tf(bl.EOF);switch(_l.value){case",":return void(Il="beforePropertyName");case"}":Ql()}},beforeArrayValue(){if("eof"===_l.type)throw tf(bl.EOF);"punctuator"!==_l.type||"]"!==_l.value?Zl():Ql()},afterArrayValue(){if("eof"===_l.type)throw tf(bl.EOF);switch(_l.value){case",":return void(Il="beforeArrayValue");case"]":Ql()}},end(){}};function Zl(){const e=function(){let e;switch(_l.type){case"punctuator":switch(_l.value){case"{":e={};break;case"[":e=[]}break;case"null":case"boolean":case"numeric":case"string":e=_l.value}return e}();if(jl&&"object"==typeof e&&(e._line=Ml,e._column=Ll),void 0===kl)kl=e;else{const t=Tl[Tl.length-1];Array.isArray(t)?jl&&"object"!=typeof e?t.push({value:e,_line:Ml,_column:Ll}):t.push(e):t[Pl]=jl&&"object"!=typeof e?{value:e,_line:Ml,_column:Ll}:e}!function(e){if(e&&"object"==typeof e)Tl.push(e),Il=Array.isArray(e)?"beforeArrayValue":"beforePropertyName";else{const e=Tl[Tl.length-1];Il=e?Array.isArray(e)?"afterArrayValue":"afterPropertyValue":"end"}}(e)}function Ql(){Tl.pop();const e=Tl[Tl.length-1];Il=e?Array.isArray(e)?"afterArrayValue":"afterPropertyValue":"end"}function ef(e){const t={"'":"\\'",'"':'\\"',"\\":"\\\\","\b":"\\b","\f":"\\f","\n":"\\n","\r":"\\r","\t":"\\t","\v":"\\v","\0":"\\0","\u2028":"\\u2028","\u2029":"\\u2029"};if(t[e])return t[e];if(e<" "){const t=e.charCodeAt(0).toString(16);return`\\x${`00${t}`.substring(t.length)}`}return e}function tf(e,t){let n="";switch(e){case bl.Char:n=void 0===t?`JSON5: invalid end of input at ${Ml}:${Ll}`:`JSON5: invalid character '${ef(t)}' at ${Ml}:${Ll}`;break;case bl.EOF:n=`JSON5: invalid end of input at ${Ml}:${Ll}`;break;case bl.Identifier:Ll-=5,n=`JSON5: invalid identifier character at ${Ml}:${Ll}`}const r=new nf(n);return r.lineNumber=Ml,r.columnNumber=Ll,r}class nf extends SyntaxError{}var rf=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),uf=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),of=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)"default"!==n&&Object.prototype.hasOwnProperty.call(e,n)&&rf(t,e,n);return uf(t,e),t};Object.defineProperty(Y,"__esModule",{value:!0});var sf=Y.cleanWorkSpace=Ff=Y.executeInstallHvigor=yf=Y.isHvigorInstalled=mf=Y.isAllDependenciesInstalled=void 0;const cf=of(D.default),af=of(p.default),lf=b,ff=j,df=$,Df=X;let pf,Ef;var mf=Y.isAllDependenciesInstalled=function(){function e(e){const t=null==e?void 0:e.dependencies;return void 0===t?0:Object.getOwnPropertyNames(t).length}if(pf=gf(),Ef=Af(),e(pf)+1!==e(Ef))return!1;for(const e in null==pf?void 0:pf.dependencies)if(!(0,ff.hasNpmPackInPaths)(e,[lf.HVIGOR_PROJECT_DEPENDENCIES_HOME])||!hf(e,pf,Ef))return!1;return!0};function hf(e,t,n){return void 0!==n.dependencies&&(0,ff.offlinePluginConversion)(lf.HVIGOR_PROJECT_ROOT_DIR,t.dependencies[e])===n.dependencies[e]}var yf=Y.isHvigorInstalled=function(){return pf=gf(),Ef=Af(),(0,ff.hasNpmPackInPaths)(lf.HVIGOR_ENGINE_PACKAGE_NAME,[lf.HVIGOR_PROJECT_DEPENDENCIES_HOME])&&(0,ff.offlinePluginConversion)(lf.HVIGOR_PROJECT_ROOT_DIR,pf.hvigorVersion)===Ef.dependencies[lf.HVIGOR_ENGINE_PACKAGE_NAME]};const Cf={cwd:lf.HVIGOR_PROJECT_DEPENDENCIES_HOME,stdio:["inherit","inherit","inherit"]};var Ff=Y.executeInstallHvigor=function(){(0,df.logInfoPrintConsole)("Hvigor installing...");const e={dependencies:{}};e.dependencies[lf.HVIGOR_ENGINE_PACKAGE_NAME]=(0,ff.offlinePluginConversion)(lf.HVIGOR_PROJECT_ROOT_DIR,pf.hvigorVersion);try{cf.mkdirSync(lf.HVIGOR_PROJECT_DEPENDENCIES_HOME,{recursive:!0});const t=af.resolve(lf.HVIGOR_PROJECT_DEPENDENCIES_HOME,lf.DEFAULT_PACKAGE_JSON);cf.writeFileSync(t,JSON.stringify(e))}catch(e){(0,df.logErrorAndExit)(e)}!function(){const e=["config","set","store-dir",lf.HVIGOR_PNPM_STORE_PATH];(0,ff.executeCommand)(lf.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH,e,Cf)}(),(0,ff.executeCommand)(lf.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH,["install"],Cf)};function gf(){const e=af.resolve(lf.HVIGOR_PROJECT_WRAPPER_HOME,lf.DEFAULT_HVIGOR_CONFIG_JSON_FILE_NAME);return cf.existsSync(e)||(0,df.logErrorAndExit)(`Error: Hvigor config file ${e} does not exist.`),(0,Df.parseJsonFile)(e)}function Af(){return cf.existsSync(lf.HVIGOR_PROJECT_DEPENDENCY_PACKAGE_JSON_PATH)?(0,Df.parseJsonFile)(lf.HVIGOR_PROJECT_DEPENDENCY_PACKAGE_JSON_PATH):{dependencies:{}}}sf=Y.cleanWorkSpace=function(){if((0,df.logInfoPrintConsole)("Hvigor cleaning..."),!cf.existsSync(lf.HVIGOR_PROJECT_DEPENDENCIES_HOME))return;const e=cf.readdirSync(lf.HVIGOR_PROJECT_DEPENDENCIES_HOME);if(e&&0!==e.length){cf.existsSync(lf.HVIGOR_BOOT_JS_FILE_PATH)&&(0,ff.executeCommand)(process.argv[0],[lf.HVIGOR_BOOT_JS_FILE_PATH,"--stop-daemon"],{});try{e.forEach((e=>{cf.rmSync(af.resolve(lf.HVIGOR_PROJECT_DEPENDENCIES_HOME,e),{recursive:!0})}))}catch(e){(0,df.logErrorAndExit)(`The hvigor build tool cannot be installed. Please manually clear the workspace directory and synchronize the project again.\n\n Workspace Path: ${lf.HVIGOR_PROJECT_DEPENDENCIES_HOME}.`)}}};var vf={},Sf=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),wf=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),Of=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)"default"!==n&&Object.prototype.hasOwnProperty.call(e,n)&&Sf(t,e,n);return wf(t,e),t};Object.defineProperty(vf,"__esModule",{value:!0});var bf=vf.executeBuild=void 0;const _f=b,Bf=Of(D.default),Pf=Of(p.default),kf=$;bf=vf.executeBuild=function(){const e=Pf.resolve(_f.HVIGOR_PROJECT_DEPENDENCIES_HOME,"node_modules","@ohos","hvigor","bin","hvigor.js");try{const t=Bf.realpathSync(e);require(t)}catch(t){(0,kf.logErrorAndExit)(`Error: ENOENT: no such file ${e},delete ${_f.HVIGOR_PROJECT_DEPENDENCIES_HOME} and retry.`)}},function(){if(O.checkNpmConifg(),O.environmentHandler(),O.isPnpmAvailable()||O.executeInstallPnpm(),yf()&&mf())bf();else{sf();try{Ff()}catch(e){return void sf()}bf()}}();
\ No newline at end of file
diff --git a/storage/storagefileiov9jstest/hvigorfile.ts b/storage/storagefileiov9jstest/hvigorfile.ts
deleted file mode 100644
index 0b9c10fc3ade5a54609b2d639f808ca7c25a611a..0000000000000000000000000000000000000000
--- a/storage/storagefileiov9jstest/hvigorfile.ts
+++ /dev/null
@@ -1,16 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-// Script for compiling build behavior. It is built in the build plug-in and cannot be modified currently.
-export { legacyAppTasks } from '@ohos/hvigor-ohos-plugin';
\ No newline at end of file
diff --git a/storage/storagefileiov9jstest/hvigorw b/storage/storagefileiov9jstest/hvigorw
deleted file mode 100755
index b4d7760e72934718fc616fcef2806a1c7f04ba34..0000000000000000000000000000000000000000
--- a/storage/storagefileiov9jstest/hvigorw
+++ /dev/null
@@ -1,61 +0,0 @@
-# Copyright (c) 2023 Huawei Device Co., Ltd.
-# Licensed under the Apache License, Version 2.0 (the "License");
-# you may not use this file except in compliance with the License.
-# You may obtain a copy of the License at
-#
-# http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-
-#!/bin/bash
-
-# ----------------------------------------------------------------------------
-# Hvigor startup script, version 1.0.0
-#
-# Required ENV vars:
-# ------------------
-# NODE_HOME - location of a Node home dir
-# or
-# Add /usr/local/nodejs/bin to the PATH environment variable
-# ----------------------------------------------------------------------------
-
-HVIGOR_APP_HOME=$(dirname $(readlink -f $0))
-HVIGOR_WRAPPER_SCRIPT=${HVIGOR_APP_HOME}/hvigor/hvigor-wrapper.js
-warn() {
- echo ""
- echo -e "\033[1;33m`date '+[%Y-%m-%d %H:%M:%S]'`$@\033[0m"
-}
-
-error() {
- echo ""
- echo -e "\033[1;31m`date '+[%Y-%m-%d %H:%M:%S]'`$@\033[0m"
-}
-
-fail() {
- error "$@"
- exit 1
-}
-
-# Determine node to start hvigor wrapper script
-if [ -n "${NODE_HOME}" ];then
- EXECUTABLE_NODE="${NODE_HOME}/bin/node"
- if [ ! -x "$EXECUTABLE_NODE" ];then
- fail "ERROR: NODE_HOME is set to an invalid directory,check $NODE_HOME\n\nPlease set NODE_HOME in your environment to the location where your nodejs installed"
- fi
-else
- EXECUTABLE_NODE="node"
- which ${EXECUTABLE_NODE} > /dev/null 2>&1 || fail "ERROR: NODE_HOME is not set and not 'node' command found in your path"
-fi
-
-# Check hvigor wrapper script
-if [ ! -r "$HVIGOR_WRAPPER_SCRIPT" ];then
- fail "ERROR: Couldn't find hvigor/hvigor-wrapper.js in ${HVIGOR_APP_HOME}"
-fi
-
-# start hvigor-wrapper script
-exec "${EXECUTABLE_NODE}" \
- "${HVIGOR_WRAPPER_SCRIPT}" "$@"
diff --git a/storage/storagefileiov9jstest/hvigorw.bat b/storage/storagefileiov9jstest/hvigorw.bat
deleted file mode 100644
index a9cc1302dc821de7f9f82c3327673a730945ec7d..0000000000000000000000000000000000000000
--- a/storage/storagefileiov9jstest/hvigorw.bat
+++ /dev/null
@@ -1,70 +0,0 @@
-@rem Copyright (C) 2023 Huawei Device Co., Ltd.
-@rem Licensed under the Apache License, Version 2.0 (the "License");
-@rem you may not use this file except in compliance with the License.
-@rem You may obtain a copy of the License at
-@rem
-@rem http://www.apache.org/licenses/LICENSE-2.0
-@rem
-@rem Unless required by applicable law or agreed to in writing, software
-@rem distributed under the License is distributed on an "AS IS" BASIS,
-@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-@rem See the License for the specific language governing permissions and
-@rem limitations under the License.
-
-@if "%DEBUG%" == "" @echo off
-@rem ##########################################################################
-@rem
-@rem Hvigor startup script for Windows
-@rem
-@rem ##########################################################################
-
-@rem Set local scope for the variables with windows NT shell
-if "%OS%"=="Windows_NT" setlocal
-
-set DIRNAME=%~dp0
-if "%DIRNAME%" == "" set DIRNAME=.
-set APP_BASE_NAME=%~n0
-set APP_HOME=%DIRNAME%
-
-@rem Resolve any "." and ".." in APP_HOME to make it shorter.
-for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi
-
-set WRAPPER_MODULE_PATH=%APP_HOME%\hvigor\hvigor-wrapper.js
-set NODE_EXE=node.exe
-
-goto start
-
-:start
-@rem Find node.exe
-if defined NODE_HOME goto findNodeFromNodeHome
-
-%NODE_EXE% --version >NUL 2>&1
-if "%ERRORLEVEL%" == "0" goto execute
-
-echo.
-echo ERROR: NODE_HOME is not set and no 'node' command could be found in your PATH.
-echo.
-echo Please set the NODE_HOME variable in your environment to match the
-echo location of your NodeJs installation.
-
-goto fail
-
-:findNodeFromNodeHome
-set NODE_HOME=%NODE_HOME:"=%
-set NODE_EXE_PATH=%NODE_HOME%/%NODE_EXE%
-
-if exist "%NODE_EXE_PATH%" goto execute
-echo.
-echo ERROR: NODE_HOME is not set and no 'node' command could be found in your PATH.
-echo.
-echo Please set the NODE_HOME variable in your environment to match the
-echo location of your NodeJs installation.
-
-goto fail
-
-:execute
-@rem Execute hvigor
-"%NODE_EXE%" %WRAPPER_MODULE_PATH% %*
-
-:fail
-exit /b 1
diff --git a/storage/storagefileiov9jstest/oh-package.json5 b/storage/storagefileiov9jstest/oh-package.json5
deleted file mode 100644
index 1a98aac1810691829d1f9908395de4863cb0623d..0000000000000000000000000000000000000000
--- a/storage/storagefileiov9jstest/oh-package.json5
+++ /dev/null
@@ -1,26 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-{
- "license": "",
- "devDependencies": {
- "@ohos/hypium": "1.0.6"
- },
- "author": "",
- "name": "myapplication454434",
- "description": "Please describe the basic information.",
- "main": "",
- "version": "1.0.0",
- "dependencies": {}
-}
diff --git a/storage/storagefileiov9jstest/src/main/config.json b/storage/storagefileiov9jstest/src/main/config.json
new file mode 100644
index 0000000000000000000000000000000000000000..f671d3531f88ccd26e77aed2fe553269224df53c
--- /dev/null
+++ b/storage/storagefileiov9jstest/src/main/config.json
@@ -0,0 +1,95 @@
+{
+ "app": {
+ "bundleName": "ohos.acts.storage.fileiov9",
+ "vendor": "example",
+ "version": {
+ "code": 1000000,
+ "name": "1.0.0"
+ },
+ "apiVersion": {
+ "compatible": 4,
+ "target": 5
+ }
+ },
+ "deviceConfig": {},
+ "module": {
+ "package": "ohos.acts.storage.fileiov9",
+ "name": ".entry",
+ "deviceType": [
+ "default",
+ "tablet"
+ ],
+ "distro": {
+ "deliveryWithInstall": true,
+ "moduleName": "entry",
+ "moduleType": "entry",
+ "installationFree": true
+ },
+ "abilities": [
+ {
+ "skills": [
+ {
+ "entities": [
+ "entity.system.home"
+ ],
+ "actions": [
+ "action.system.home"
+ ]
+ }
+ ],
+ "orientation": "unspecified",
+ "formsEnabled": false,
+ "name": ".MainAbility",
+ "srcLanguage": "js",
+ "srcPath": "MainAbility",
+ "icon": "$media:icon",
+ "description": "$string:MainAbility_desc",
+ "label": "$string:MainAbility_label",
+ "type": "page",
+ "visible": true,
+ "launchType": "standard"
+ },
+ {
+ "orientation": "unspecified",
+ "formsEnabled": false,
+ "name": ".TestAbility",
+ "srcLanguage": "js",
+ "srcPath": "TestAbility",
+ "icon": "$media:icon",
+ "description": "$string:TestAbility_desc",
+ "label": "$string:TestAbility_label",
+ "type": "page",
+ "visible": true,
+ "launchType": "standard"
+ }
+ ],
+ "js": [
+ {
+ "pages": [
+ "pages/index/index"
+ ],
+ "name": "default",
+ "window": {
+ "designWidth": 720,
+ "autoDesignWidth": false
+ }
+ },
+ {
+ "pages": [
+ "pages/index/index"
+ ],
+ "name": ".TestAbility",
+ "window": {
+ "designWidth": 720,
+ "autoDesignWidth": false
+ }
+ }
+ ],
+ "testRunner": {
+ "name": "OpenHarmonyTestRunner",
+ "srcPath": "TestRunner"
+ },
+ "mainAbility": ".MainAbility",
+ "srcPath": ""
+ }
+}
diff --git a/storage/storagefileiov9jstest/src/main/js/MainAbility/app.js b/storage/storagefileiov9jstest/src/main/js/MainAbility/app.js
new file mode 100644
index 0000000000000000000000000000000000000000..ff6de3ed7a2189ab31dbded34284eb4ce87f644e
--- /dev/null
+++ b/storage/storagefileiov9jstest/src/main/js/MainAbility/app.js
@@ -0,0 +1,23 @@
+/*
+ * Copyright (C) 2022 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+export default {
+ onCreate() {
+ console.info('ohos.acts.storage.fileio onCreate');
+ },
+ onDestroy() {
+ console.info('ohos.acts.storage.fileio onDestroy');
+ }
+};
diff --git a/storage/storagefileiov9jstest/entry/src/main/js/MainAbility/i18n/en-US.json b/storage/storagefileiov9jstest/src/main/js/MainAbility/i18n/en-US.json
similarity index 61%
rename from storage/storagefileiov9jstest/entry/src/main/js/MainAbility/i18n/en-US.json
rename to storage/storagefileiov9jstest/src/main/js/MainAbility/i18n/en-US.json
index a4c13dcbdc39c537073f638393d7726ac9a5cdc4..ead52ed2e09ec82aaf7aa9f4e714ed39ea88308e 100644
--- a/storage/storagefileiov9jstest/entry/src/main/js/MainAbility/i18n/en-US.json
+++ b/storage/storagefileiov9jstest/src/main/js/MainAbility/i18n/en-US.json
@@ -1,6 +1,6 @@
-{
- "strings": {
- "hello": "Hello",
- "world": "World"
- }
+{
+ "strings": {
+ "hello": "Hello",
+ "world": "Test"
+ }
}
\ No newline at end of file
diff --git a/storage/storagefilejstest/entry/src/main/js/MainAbility/i18n/zh-CN.json b/storage/storagefileiov9jstest/src/main/js/MainAbility/i18n/zh-CN.json
similarity index 61%
rename from storage/storagefilejstest/entry/src/main/js/MainAbility/i18n/zh-CN.json
rename to storage/storagefileiov9jstest/src/main/js/MainAbility/i18n/zh-CN.json
index b1c02368f72f929e4375a43170444de95dcc5984..3f48f2585b24a8fe4a745e8ee2972a9e991a7803 100644
--- a/storage/storagefilejstest/entry/src/main/js/MainAbility/i18n/zh-CN.json
+++ b/storage/storagefileiov9jstest/src/main/js/MainAbility/i18n/zh-CN.json
@@ -1,6 +1,6 @@
-{
- "strings": {
- "hello": "您好",
- "world": "世界"
- }
+{
+ "strings": {
+ "hello": "您好",
+ "world": "测试"
+ }
}
\ No newline at end of file
diff --git a/storage/storagefileiov9jstest/src/main/js/MainAbility/pages/index/index.css b/storage/storagefileiov9jstest/src/main/js/MainAbility/pages/index/index.css
new file mode 100644
index 0000000000000000000000000000000000000000..6fda792753f2e15f22b529c7b90a82185b2770bf
--- /dev/null
+++ b/storage/storagefileiov9jstest/src/main/js/MainAbility/pages/index/index.css
@@ -0,0 +1,9 @@
+.container {
+ flex-direction: column;
+ justify-content: center;
+ align-items: center;
+}
+
+.title {
+ font-size: 100px;
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/TestAbility/pages/index/index.hml b/storage/storagefileiov9jstest/src/main/js/MainAbility/pages/index/index.hml
similarity index 100%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/TestAbility/pages/index/index.hml
rename to storage/storagefileiov9jstest/src/main/js/MainAbility/pages/index/index.hml
diff --git a/storage/storagefileiov9jstest/src/main/js/MainAbility/pages/index/index.js b/storage/storagefileiov9jstest/src/main/js/MainAbility/pages/index/index.js
new file mode 100644
index 0000000000000000000000000000000000000000..446cc682b011e7de5a9493990e61ca8f9ce0d6eb
--- /dev/null
+++ b/storage/storagefileiov9jstest/src/main/js/MainAbility/pages/index/index.js
@@ -0,0 +1,33 @@
+/*
+ * Copyright (C) 2022 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import app from '@system.app'
+
+const injectRef = Object.getPrototypeOf(global) || global
+injectRef.regeneratorRuntime = require('@babel/runtime/regenerator')
+
+export default {
+ data: {
+ title: ''
+ },
+ onInit() {
+ this.title = this.$t('strings.world');
+ },
+ onShow() {
+ console.info('onShow finish')
+ },
+ onReady() {
+ },
+}
diff --git a/storage/storagefileurijstest/entry/src/ohosTest/js/TestAbility/app.js b/storage/storagefileiov9jstest/src/main/js/TestAbility/app.js
similarity index 62%
rename from storage/storagefileurijstest/entry/src/ohosTest/js/TestAbility/app.js
rename to storage/storagefileiov9jstest/src/main/js/TestAbility/app.js
index 469c4f1380182e0dccb04f17eb95d9b503a56d29..d5ee271df29e516d1c8929054283e5f2bf5c981c 100644
--- a/storage/storagefileurijstest/entry/src/ohosTest/js/TestAbility/app.js
+++ b/storage/storagefileiov9jstest/src/main/js/TestAbility/app.js
@@ -1,33 +1,31 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-import hilog from '@ohos.hilog';
-import AbilityDelegatorRegistry from '@ohos.app.ability.abilityDelegatorRegistry';
-import { Hypium } from '@ohos/hypium';
-import testsuite from '../test/List.test';
-
-export default {
- onCreate() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'TestApplication onCreate');
- var abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator()
- var abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments()
- hilog.info(0x0000, 'testTag', '%{public}s', 'start run testcase!!!');
- Hypium.hypiumTest(abilityDelegator, abilityDelegatorArguments, testsuite)
- },
- onDestroy() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'TestApplication onDestroy');
- }
-};
-
-
+/*
+ * Copyright (c) 2022 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry'
+import { Hypium } from '@ohos/hypium'
+import testsuite from '../test/List.test'
+
+export default {
+ onCreate() {
+ console.info('TestApplication onCreate')
+ var abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator()
+ var abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments()
+ console.info('start run testcase!!!')
+ Hypium.hypiumTest(abilityDelegator, abilityDelegatorArguments, testsuite)
+ },
+ onDestroy() {
+ console.info("TestApplication onDestroy");
+ }
+};
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/TestAbility/i18n/en-US.json b/storage/storagefileiov9jstest/src/main/js/TestAbility/i18n/en-US.json
similarity index 100%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/TestAbility/i18n/en-US.json
rename to storage/storagefileiov9jstest/src/main/js/TestAbility/i18n/en-US.json
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/TestAbility/i18n/zh-CN.json b/storage/storagefileiov9jstest/src/main/js/TestAbility/i18n/zh-CN.json
similarity index 100%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/TestAbility/i18n/zh-CN.json
rename to storage/storagefileiov9jstest/src/main/js/TestAbility/i18n/zh-CN.json
diff --git a/storage/storagesecuritylabeljstest/entry/src/ohosTest/js/TestAbility/pages/index/index.css b/storage/storagefileiov9jstest/src/main/js/TestAbility/pages/index/index.css
similarity index 94%
rename from storage/storagesecuritylabeljstest/entry/src/ohosTest/js/TestAbility/pages/index/index.css
rename to storage/storagefileiov9jstest/src/main/js/TestAbility/pages/index/index.css
index b1bcd43387ba131cc1d30975ff7508a6f8084a4b..b21c92c6290ea747bd891e2ab673721afc5521ed 100644
--- a/storage/storagesecuritylabeljstest/entry/src/ohosTest/js/TestAbility/pages/index/index.css
+++ b/storage/storagefileiov9jstest/src/main/js/TestAbility/pages/index/index.css
@@ -1,30 +1,30 @@
-.container {
- display: flex;
- flex-direction: column;
- justify-content: center;
- align-items: center;
- left: 0px;
- top: 0px;
- width: 100%;
- height: 100%;
-}
-
-.title {
- font-size: 60px;
- text-align: center;
- width: 100%;
- height: 40%;
- margin: 10px;
-}
-
-@media screen and (device-type: phone) and (orientation: landscape) {
- .title {
- font-size: 60px;
- }
-}
-
-@media screen and (device-type: tablet) and (orientation: landscape) {
- .title {
- font-size: 100px;
- }
+.container {
+ display: flex;
+ flex-direction: column;
+ justify-content: center;
+ align-items: center;
+ left: 0px;
+ top: 0px;
+ width: 100%;
+ height: 100%;
+}
+
+.title {
+ font-size: 60px;
+ text-align: center;
+ width: 100%;
+ height: 40%;
+ margin: 10px;
+}
+
+@media screen and (device-type: phone) and (orientation: landscape) {
+ .title {
+ font-size: 60px;
+ }
+}
+
+@media screen and (device-type: tablet) and (orientation: landscape) {
+ .title {
+ font-size: 100px;
+ }
}
\ No newline at end of file
diff --git a/storage/storagefilejstest/entry/src/ohosTest/js/TestAbility/pages/index/index.hml b/storage/storagefileiov9jstest/src/main/js/TestAbility/pages/index/index.hml
similarity index 100%
rename from storage/storagefilejstest/entry/src/ohosTest/js/TestAbility/pages/index/index.hml
rename to storage/storagefileiov9jstest/src/main/js/TestAbility/pages/index/index.hml
diff --git a/storage/storagefilejstest/entry/src/ohosTest/js/TestAbility/pages/index/index.js b/storage/storagefileiov9jstest/src/main/js/TestAbility/pages/index/index.js
similarity index 92%
rename from storage/storagefilejstest/entry/src/ohosTest/js/TestAbility/pages/index/index.js
rename to storage/storagefileiov9jstest/src/main/js/TestAbility/pages/index/index.js
index ad113c0d214ce0d80c42c75c62d881547b6294ee..e7cd2973f81dfe6ca5f3a93aae440cdcfdba3188 100644
--- a/storage/storagefilejstest/entry/src/ohosTest/js/TestAbility/pages/index/index.js
+++ b/storage/storagefileiov9jstest/src/main/js/TestAbility/pages/index/index.js
@@ -1,5 +1,5 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
+/*
+ * Copyright (c) 2022 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
@@ -12,6 +12,7 @@
* See the License for the specific language governing permissions and
* limitations under the License.
*/
+
export default {
data: {
title: ""
@@ -20,6 +21,3 @@ export default {
this.title = this.$t('strings.world');
}
}
-
-
-
diff --git a/storage/storagefileurijstest/entry/src/ohosTest/js/TestRunner/OpenHarmonyTestRunner.js b/storage/storagefileiov9jstest/src/main/js/TestRunner/OpenHarmonyTestRunner.js
similarity index 52%
rename from storage/storagefileurijstest/entry/src/ohosTest/js/TestRunner/OpenHarmonyTestRunner.js
rename to storage/storagefileiov9jstest/src/main/js/TestRunner/OpenHarmonyTestRunner.js
index 03ccc5b691574b1d5bc46adefc08d9ddfc4a1f5c..b9e78ce7cf73f1ade6ba52a408a44e33f5430f0d 100644
--- a/storage/storagefileurijstest/entry/src/ohosTest/js/TestRunner/OpenHarmonyTestRunner.js
+++ b/storage/storagefileiov9jstest/src/main/js/TestRunner/OpenHarmonyTestRunner.js
@@ -1,5 +1,5 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
+/*
+ * Copyright (c) 2022 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
@@ -12,30 +12,48 @@
* See the License for the specific language governing permissions and
* limitations under the License.
*/
-import hilog from '@ohos.hilog';
-import AbilityDelegatorRegistry from '@ohos.app.ability.abilityDelegatorRegistry';
+
+import AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry'
+
+function translateParamsToString(parameters) {
+ const keySet = new Set([
+ '-s class', '-s notClass', '-s suite', '-s itName',
+ '-s level', '-s testType', '-s size', '-s timeout',
+ '-s package', '-s dryRun'
+ ])
+ let targetParams = '';
+ for (const key in parameters) {
+ if (keySet.has(key)) {
+ targetParams += ' ' + key + ' ' + parameters[key]
+ }
+ }
+ return targetParams.trim()
+}
export default {
onPrepare() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'OpenHarmonyTestRunner OnPrepare');
+ console.info('OpenHarmonyTestRunner OnPrepare')
},
onRun() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'OpenHarmonyTestRunner onRun run');
+ console.log('OpenHarmonyTestRunner onRun run')
var abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments()
var abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator()
var testAbilityName = abilityDelegatorArguments.parameters['-p'] + '.TestAbility'
+
var cmd = 'aa start -d 0 -a ' + testAbilityName + ' -b ' + abilityDelegatorArguments.bundleName
+ cmd += ' ' + translateParamsToString(abilityDelegatorArguments.parameters)
var debug = abilityDelegatorArguments.parameters["-D"]
+ console.info('debug value : '+debug)
if (debug == 'true')
{
cmd += ' -D'
}
- hilog.info(0x0000, 'testTag', 'cmd : %{public}s', cmd);
+ console.info('cmd : '+cmd)
abilityDelegator.executeShellCommand(cmd, (err, data) => {
- hilog.info(0x0000, 'testTag', 'executeShellCommand : err : %{public}s', JSON.stringify(err) ?? '');
- hilog.info(0x0000, 'testTag', 'executeShellCommand : data : %{public}s', data.stdResult ?? '');
- hilog.info(0x0000, 'testTag', 'executeShellCommand : data : %{public}s', data.exitCode ?? '');
+ console.info('executeShellCommand : err : ' + JSON.stringify(err));
+ console.info('executeShellCommand : data : ' + data.stdResult);
+ console.info('executeShellCommand : data : ' + data.exitCode);
})
}
-};
\ No newline at end of file
+};
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/Common.js b/storage/storagefileiov9jstest/src/main/js/test/Common.js
similarity index 90%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/Common.js
rename to storage/storagefileiov9jstest/src/main/js/test/Common.js
index ae02a240786dcacb29fd2c90088cc989af43dc04..3ba48a1cb1a68f3f8c2249d04ca5b9c371589086 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/Common.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/Common.js
@@ -1,107 +1,107 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import fileIO from '@ohos.file.fs';
-import util from '@ohos.util';
-import featureAbility from '@ohos.ability.featureAbility';
-
-export const FILE_CONTENT = 'hello world';
-
-import {
- describe, it, expect
-}
-from '@ohos/hypium'
-
-export function prepareFile(fpath, content) {
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.CREATE | fileIO.OpenMode.READ_WRITE)
- fileIO.truncateSync(file.fd)
- fileIO.writeSync(file.fd, content)
- fileIO.fsyncSync(file.fd)
- fileIO.closeSync(file)
- return true
- }
- catch (e) {
- console.log('Failed to prepareFile for ' + e)
- return false
- }
-}
-
-export function prepare200MFile(fpath) {
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.CREATE | fileIO.OpenMode.READ_WRITE)
- fileIO.truncateSync(file.fd)
- let bf = new ArrayBuffer(1024 * 1024 * 20);
- for (let i = 0; i < 10; i++) {
- let position = bf.byteLength * i;
- let writeLen = fileIO.writeSync(file.fd, bf, { offset: 0, length: bf.byteLength, position: position, encoding: 'utf-8' });
- }
- fileIO.fsyncSync(file.fd)
- fileIO.closeSync(file)
- return true
- }
- catch (e) {
- console.log('Failed to prepare200MFile for ' + e)
- return false
- }
-}
-
-export async function nextFileName(testName) {
- let context = featureAbility.getContext();
- let data = await context.getCacheDir();
- let BASE_PATH = data + '/';
- return BASE_PATH + testName + '_' + randomString(testName.length);
-}
-
-export async function fileName(testName) {
- let context = featureAbility.getContext();
- let data = await context.getFilesDir();
- let BASE_PATH = data + '/';
- return BASE_PATH + testName + '_' + randomString(testName.length);
-}
-
-export function randomString(num) {
- let len= num;
- var $chars = 'aaaabbbbcccc';
- var maxPos = $chars.length;
- var pwd = '';
- for (var i = 0; i < len; i++) {
- pwd += $chars.charAt(Math.floor(Math.random() * maxPos));
- }
- return pwd;
-}
-
-function isIntNum(val) {
- return typeof val === 'number' && val % 1 === 0;
-}
-
-function isBigInt(val) {
- return typeof val === 'bigint';
-}
-
-function isString(str) {
- return (typeof str == 'string') && str.constructor == String;
-}
-
-export {
- fileIO,
- isIntNum,
- isBigInt,
- isString,
- describe,
- it,
- expect,
- util
+/*
+ * Copyright (C) 2022-2023 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import fileIO from '@ohos.file.fs';
+import util from '@ohos.util';
+import featureAbility from '@ohos.ability.featureAbility';
+
+export const FILE_CONTENT = 'hello world';
+
+import {
+ describe, it, expect
+}
+from '@ohos/hypium'
+
+export function prepareFile(fpath, content) {
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.CREATE | fileIO.OpenMode.READ_WRITE)
+ fileIO.truncateSync(file.fd)
+ fileIO.writeSync(file.fd, content)
+ fileIO.fsyncSync(file.fd)
+ fileIO.closeSync(file)
+ return true
+ }
+ catch (e) {
+ console.log('Failed to prepareFile for ' + e)
+ return false
+ }
+}
+
+export function prepare200MFile(fpath) {
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.CREATE | fileIO.OpenMode.READ_WRITE)
+ fileIO.truncateSync(file.fd)
+ let bf = new ArrayBuffer(1024 * 1024 * 20);
+ for (let i = 0; i < 10; i++) {
+ let position = bf.byteLength * i;
+ let writeLen = fileIO.writeSync(file.fd, bf, { offset: 0, length: bf.byteLength, position: position, encoding: 'utf-8' });
+ }
+ fileIO.fsyncSync(file.fd)
+ fileIO.closeSync(file)
+ return true
+ }
+ catch (e) {
+ console.log('Failed to prepare200MFile for ' + e)
+ return false
+ }
+}
+
+export async function nextFileName(testName) {
+ let context = featureAbility.getContext();
+ let data = await context.getCacheDir();
+ let BASE_PATH = data + '/';
+ return BASE_PATH + testName + '_' + randomString(testName.length);
+}
+
+export async function fileName(testName) {
+ let context = featureAbility.getContext();
+ let data = await context.getFilesDir();
+ let BASE_PATH = data + '/';
+ return BASE_PATH + testName + '_' + randomString(testName.length);
+}
+
+export function randomString(num) {
+ let len= num;
+ var $chars = 'aaaabbbbcccc';
+ var maxPos = $chars.length;
+ var pwd = '';
+ for (var i = 0; i < len; i++) {
+ pwd += $chars.charAt(Math.floor(Math.random() * maxPos));
+ }
+ return pwd;
+}
+
+function isIntNum(val) {
+ return typeof val === 'number' && val % 1 === 0;
+}
+
+function isBigInt(val) {
+ return typeof val === 'bigint';
+}
+
+function isString(str) {
+ return (typeof str == 'string') && str.constructor == String;
+}
+
+export {
+ fileIO,
+ isIntNum,
+ isBigInt,
+ isString,
+ describe,
+ it,
+ expect,
+ util
};
\ No newline at end of file
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/List.test.js b/storage/storagefileiov9jstest/src/main/js/test/List.test.js
similarity index 95%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/List.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/List.test.js
index 26958f066053eb8af984037c83d37f6c81fb6f4c..905f173b971f973d2e248851adee2a4a19db4bbb 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/List.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/List.test.js
@@ -1,79 +1,79 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import fileIOAccess from './members/access.test.js'
-import fileIOClose from './members/close.test.js'
-import fileIOCopyDir from './members/copyDir.test'
-import fileIOCopyfile from './members/copyFile.test.js'
-import fileIOCreateStream from './members/createStream.test.js'
-import fileIOFdatasync from './members/fdatasync.test.js'
-import fileIOFdOpenStream from './members/fdopenStream.test.js'
-import fileIOFileLock from './members/fileLock.test.js'
-import fileIOFsync from './members/fsync.test.js'
-import fileIOHash from './members/hash.test.js'
-import fileIOListfile from './members/listFile.test.js'
-import fileIOLstat from './members/lstat.test.js'
-import fileIOMkdir from './members/mkdir.test.js'
-import fileIOMkdtemp from './members/mkdtemp.test.js'
-import fileIOMoveDir from './members/moveDir.test.js'
-import fileIOMoveFile from './members/moveFile.test.js'
-import fileIOOpen from './members/open.test.js'
-import fileIORead from './members/read.test.js'
-import fileIOReadtext from './members/readtext.test.js'
-import fileIORename from './members/rename.test.js'
-import fileIORmdir from './members/rmdir.test'
-import fileIOStat from './members/stat.test.js'
-import fileIOStreamClose from './class_stream/close.test.js'
-import fileIOStreamFlush from './class_stream/flush.test.js'
-import fileIOStreamRead from './class_stream/read.test.js'
-import fileIOStreamWrite from './class_stream/write.test.js'
-import fileIOSymlink from './members/symlink.test.js'
-import fileIOTruncate from './members/truncate.test.js'
-import fileIOUnlink from './members/unlink.test.js'
-import fileIOWrite from './members/write.test.js'
-import fileIORW from './members/filerw.test.js'
-export default function testsuite() {
- fileIOAccess()
- fileIOClose()
- fileIOCopyDir()
- fileIOCopyfile()
- fileIOCreateStream()
- fileIOFdatasync()
- fileIOFdOpenStream()
- fileIOFileLock()
- fileIOFsync()
- fileIOHash()
- fileIOListfile()
- fileIOLstat()
- fileIOMkdir()
- fileIOMkdtemp()
- fileIOMoveDir()
- fileIOMoveFile()
- fileIOOpen()
- fileIORead()
- fileIOReadtext()
- fileIORename()
- fileIORmdir()
- fileIOStat()
- fileIOStreamClose()
- fileIOStreamFlush()
- fileIOStreamRead()
- fileIOStreamWrite()
- fileIOSymlink()
- fileIOTruncate()
- fileIOUnlink()
- fileIOWrite()
- fileIORW()
-}
+/*
+ * Copyright (C) 2022-2023 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import fileIOAccess from './members/access.test.js'
+import fileIOClose from './members/close.test.js'
+import fileIOCopyDir from './members/copyDir.test'
+import fileIOCopyfile from './members/copyFile.test.js'
+import fileIOCreateStream from './members/createStream.test.js'
+import fileIOFdatasync from './members/fdatasync.test.js'
+import fileIOFdOpenStream from './members/fdopenStream.test.js'
+import fileIOFileLock from './members/fileLock.test.js'
+import fileIOFsync from './members/fsync.test.js'
+import fileIOHash from './members/hash.test.js'
+import fileIOListfile from './members/listFile.test.js'
+import fileIOLstat from './members/lstat.test.js'
+import fileIOMkdir from './members/mkdir.test.js'
+import fileIOMkdtemp from './members/mkdtemp.test.js'
+import fileIOMoveDir from './members/moveDir.test.js'
+import fileIOMoveFile from './members/moveFile.test.js'
+import fileIOOpen from './members/open.test.js'
+import fileIORead from './members/read.test.js'
+import fileIOReadtext from './members/readtext.test.js'
+import fileIORename from './members/rename.test.js'
+import fileIORmdir from './members/rmdir.test'
+import fileIOStat from './members/stat.test.js'
+import fileIOStreamClose from './class_stream/close.test.js'
+import fileIOStreamFlush from './class_stream/flush.test.js'
+import fileIOStreamRead from './class_stream/read.test.js'
+import fileIOStreamWrite from './class_stream/write.test.js'
+import fileIOSymlink from './members/symlink.test.js'
+import fileIOTruncate from './members/truncate.test.js'
+import fileIOUnlink from './members/unlink.test.js'
+import fileIOWrite from './members/write.test.js'
+import fileIORW from './members/filerw.test.js'
+export default function testsuite() {
+ fileIOAccess()
+ fileIOClose()
+ fileIOCopyDir()
+ fileIOCopyfile()
+ fileIOCreateStream()
+ fileIOFdatasync()
+ fileIOFdOpenStream()
+ fileIOFileLock()
+ fileIOFsync()
+ fileIOHash()
+ fileIOListfile()
+ fileIOLstat()
+ fileIOMkdir()
+ fileIOMkdtemp()
+ fileIOMoveDir()
+ fileIOMoveFile()
+ fileIOOpen()
+ fileIORead()
+ fileIOReadtext()
+ fileIORename()
+ fileIORmdir()
+ fileIOStat()
+ fileIOStreamClose()
+ fileIOStreamFlush()
+ fileIOStreamRead()
+ fileIOStreamWrite()
+ fileIOSymlink()
+ fileIOTruncate()
+ fileIOUnlink()
+ fileIOWrite()
+ fileIORW()
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/class_stream/close.test.js b/storage/storagefileiov9jstest/src/main/js/test/class_stream/close.test.js
similarity index 94%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/class_stream/close.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/class_stream/close.test.js
index 72fdb150f5fd4fdc7b3b88dcc2ebbd37ef65fdf0..f529d0775e284e55bb3b710f34e469486d4c8e6d 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/class_stream/close.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/class_stream/close.test.js
@@ -1,214 +1,214 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import {
- fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect,
-} from '../Common';
-
-export default function fileIOStreamClose() {
-describe('fileIO_fs_stream_close', function () {
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_CLOSE_SYNC_0000
- * @tc.name fileIO_test_stream_close_sync_000
- * @tc.desc Test the closeSync() interface of class Stream.
- * Open a file stream, close file stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_stream_close_sync_000', 0, async function () {
- let fpath = await nextFileName('fileIO_test_stream_close_sync_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r');
- expect(sr !== null).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_stream_close_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- })
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_CLOSE_SYNC_0100
- * @tc.name fileIO_test_stream_close_sync_001
- * @tc.desc Test the closeSync() interface of class Stream.
- * Invalid parameter, don't requrie any parameters.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_close_sync_001', 0, async function () {
- let fpath = await nextFileName('fileIO_test_stream_close_sync_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let sr = fileIO.createStreamSync(fpath, 'r');
-
- try {
- expect(sr !== null).assertTrue();
- sr.closeSync(1);
- expect(false).assertTrue();
- } catch (e) {
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_stream_close_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- })
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_CLOSE_SYNC_0200
- * @tc.name fileIO_test_stream_close_sync_002
- * @tc.desc Test the closeSync() interface of class Stream.
- * The file stream has been closed.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_close_sync_002', 0, async function () {
- let fpath = await nextFileName('fileIO_test_stream_close_sync_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let sr = fileIO.createStreamSync(fpath, 'r');
-
- try {
- expect(sr !== null).assertTrue();
- sr.closeSync();
- sr.closeSync();
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_stream_close_sync_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
- }
- })
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_CLOSE_ASYNC_0000
- * @tc.name fileIO_test_stream_close_async_000
- * @tc.desc Test the close() interface of class Stream. Promise.
- * Open a file stream, close file stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 1
- * @tc.require
- */
- it('fileIO_test_stream_close_async_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_close_async_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r');
- expect(sr !== null).assertTrue();
- await sr.close();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_stream_close_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_CLOSE_ASYNC_0100
- * @tc.name fileIO_test_stream_close_async_001
- * @tc.desc Test the close() interface of class Stream. Callback.
- * Open a file stream, close file stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 1
- * @tc.require
- */
- it('fileIO_test_stream_close_async_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_close_async_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r');
- expect(sr !== null).assertTrue();
- sr.close((err) => {
- if (err) {
- console.log('fileIO_test_stream_close_async_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- fileIO.unlinkSync(fpath);
- })
- done();
- } catch (e) {
- console.log('fileIO_test_stream_close_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_CLOSE_ASYNC_0200
- * @tc.name fileIO_test_stream_close_async_002
- * @tc.desc Test the close() interface of class Stream. Promise.
- * The file stream has been closed.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_close_async_002', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_close_async_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r');
- expect(sr !== null).assertTrue();
- await sr.close();
- await sr.close();
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_stream_close_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_CLOSE_ASYNC_0300
- * @tc.name fileIO_test_stream_close_async_003
- * @tc.desc Test the close() interface of class Stream. Promise.
- * Invalid parameter, don't requrie any parameters.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_close_async_003', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_close_async_003');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r');
- expect(sr !== null).assertTrue();
- await sr.close(1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_stream_close_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-})
-}
+/*
+ * Copyright (C) 2023 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import {
+ fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect,
+} from '../Common';
+
+export default function fileIOStreamClose() {
+describe('fileIO_fs_stream_close', function () {
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_CLOSE_SYNC_0000
+ * @tc.name fileIO_test_stream_close_sync_000
+ * @tc.desc Test the closeSync() interface of class Stream.
+ * Open a file stream, close file stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_stream_close_sync_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_close_sync_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r');
+ expect(sr !== null).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_stream_close_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ })
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_CLOSE_SYNC_0100
+ * @tc.name fileIO_test_stream_close_sync_001
+ * @tc.desc Test the closeSync() interface of class Stream.
+ * Invalid parameter, don't requrie any parameters.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_close_sync_001', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_close_sync_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let sr = fileIO.createStreamSync(fpath, 'r');
+
+ try {
+ expect(sr !== null).assertTrue();
+ sr.closeSync(1);
+ expect(false).assertTrue();
+ } catch (e) {
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_stream_close_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ })
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_CLOSE_SYNC_0200
+ * @tc.name fileIO_test_stream_close_sync_002
+ * @tc.desc Test the closeSync() interface of class Stream.
+ * The file stream has been closed.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_close_sync_002', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_close_sync_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let sr = fileIO.createStreamSync(fpath, 'r');
+
+ try {
+ expect(sr !== null).assertTrue();
+ sr.closeSync();
+ sr.closeSync();
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_stream_close_sync_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
+ }
+ })
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_CLOSE_ASYNC_0000
+ * @tc.name fileIO_test_stream_close_async_000
+ * @tc.desc Test the close() interface of class Stream. Promise.
+ * Open a file stream, close file stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 1
+ * @tc.require
+ */
+ it('fileIO_test_stream_close_async_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_close_async_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r');
+ expect(sr !== null).assertTrue();
+ await sr.close();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_stream_close_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_CLOSE_ASYNC_0100
+ * @tc.name fileIO_test_stream_close_async_001
+ * @tc.desc Test the close() interface of class Stream. Callback.
+ * Open a file stream, close file stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 1
+ * @tc.require
+ */
+ it('fileIO_test_stream_close_async_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_close_async_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r');
+ expect(sr !== null).assertTrue();
+ sr.close((err) => {
+ if (err) {
+ console.log('fileIO_test_stream_close_async_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ fileIO.unlinkSync(fpath);
+ })
+ done();
+ } catch (e) {
+ console.log('fileIO_test_stream_close_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_CLOSE_ASYNC_0200
+ * @tc.name fileIO_test_stream_close_async_002
+ * @tc.desc Test the close() interface of class Stream. Promise.
+ * The file stream has been closed.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_close_async_002', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_close_async_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r');
+ expect(sr !== null).assertTrue();
+ await sr.close();
+ await sr.close();
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_stream_close_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_CLOSE_ASYNC_0300
+ * @tc.name fileIO_test_stream_close_async_003
+ * @tc.desc Test the close() interface of class Stream. Promise.
+ * Invalid parameter, don't requrie any parameters.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_close_async_003', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_close_async_003');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r');
+ expect(sr !== null).assertTrue();
+ await sr.close(1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_stream_close_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+})
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/class_stream/flush.test.js b/storage/storagefileiov9jstest/src/main/js/test/class_stream/flush.test.js
similarity index 94%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/class_stream/flush.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/class_stream/flush.test.js
index 2266134bc47e78a96bcda73ad7e85a5abdec58c2..da010c79b1748bc619cb439fad9630d7a6bf9e57 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/class_stream/flush.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/class_stream/flush.test.js
@@ -1,171 +1,171 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import {
- fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect,
-} from '../Common';
-
-export default function fileIOStreamFlush() {
-describe('fileIO_fs_stream_flush', function () {
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_FLUSH_SYNC_0000
- * @tc.name fileIO_test_stream_flush_sync_000
- * @tc.desc Test the flushSync() interface of class Stream.
- * Refresh file stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_stream_flush_sync_000', 0, async function () {
- let fpath = await nextFileName('fileIO_test_stream_flush_sync_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- expect(sr.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- sr.flushSync();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_stream_flush_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_FLUSH_SYNC_0100
- * @tc.name fileIO_test_stream_flush_sync_001
- * @tc.desc Test the flushSync() interface of class Stream.
- * Invalid parameter, don't requrie any parameters.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_flush_sync_001', 0, async function () {
- let fpath = await nextFileName('fileIO_test_stream_flush_sync_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let sr = fileIO.createStreamSync(fpath, 'r+');
-
- try {
- expect(sr !== null).assertTrue();
- sr.flushSync(1);
- expect(false).assertTrue();
- } catch (e) {
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_stream_flush_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_FLUSH_ASYNC_0000
- * @tc.name fileIO_test_stream_flush_async_000
- * @tc.desc Test the flush() interface of class Stream. Promise.then().catch()
- * Refresh the file stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_flush_async_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_flush_async_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = await fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- expect(sr.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- sr.flush().then(() => {
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- }).catch((err) => {
- console.log('fileIO_test_stream_flush_async_000 error package' + JSON.stringify(err));
- expect(false).assertTrue();
- });
- } catch (e) {
- console.log('fileIO_test_stream_flush_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_FLUSH_ASYNC_0100
- * @tc.name fileIO_test_stream_flush_async_001
- * @tc.desc Test the flush() interface of class Stream. Callback.
- * Refresh the file stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 1
- * @tc.require
- */
- it('fileIO_test_stream_flush_async_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_flush_async_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = await fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- expect(sr.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- sr.flush((err) => {
- if (err) {
- console.log('fileIO_test_stream_flush_async_001 error package' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- })
- } catch (e) {
- console.log('fileIO_test_stream_flush_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_FLUSH_ASYNC_0100
- * @tc.name fileIO_test_stream_flush_async_002
- * @tc.desc Test the flush() interface of class Stream. Promise.
- * Refresh the file stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
-
- it('fileIO_test_stream_flush_async_002', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_flush_async_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let sr = fileIO.createStreamSync(fpath, 'r+');
-
- try {
- expect(sr !== null).assertTrue();
- await sr.flush(1);
- expect(false).assertTrue();
- } catch (e) {
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_stream_flush_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-});
-}
+/*
+ * Copyright (C) 2023 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import {
+ fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect,
+} from '../Common';
+
+export default function fileIOStreamFlush() {
+describe('fileIO_fs_stream_flush', function () {
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_FLUSH_SYNC_0000
+ * @tc.name fileIO_test_stream_flush_sync_000
+ * @tc.desc Test the flushSync() interface of class Stream.
+ * Refresh file stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_stream_flush_sync_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_flush_sync_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ expect(sr.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ sr.flushSync();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_stream_flush_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_FLUSH_SYNC_0100
+ * @tc.name fileIO_test_stream_flush_sync_001
+ * @tc.desc Test the flushSync() interface of class Stream.
+ * Invalid parameter, don't requrie any parameters.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_flush_sync_001', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_flush_sync_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+
+ try {
+ expect(sr !== null).assertTrue();
+ sr.flushSync(1);
+ expect(false).assertTrue();
+ } catch (e) {
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_stream_flush_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_FLUSH_ASYNC_0000
+ * @tc.name fileIO_test_stream_flush_async_000
+ * @tc.desc Test the flush() interface of class Stream. Promise.then().catch()
+ * Refresh the file stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_flush_async_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_flush_async_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = await fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ expect(sr.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ sr.flush().then(() => {
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ }).catch((err) => {
+ console.log('fileIO_test_stream_flush_async_000 error package' + JSON.stringify(err));
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ console.log('fileIO_test_stream_flush_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_FLUSH_ASYNC_0100
+ * @tc.name fileIO_test_stream_flush_async_001
+ * @tc.desc Test the flush() interface of class Stream. Callback.
+ * Refresh the file stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 1
+ * @tc.require
+ */
+ it('fileIO_test_stream_flush_async_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_flush_async_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = await fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ expect(sr.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ sr.flush((err) => {
+ if (err) {
+ console.log('fileIO_test_stream_flush_async_001 error package' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ })
+ } catch (e) {
+ console.log('fileIO_test_stream_flush_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_FLUSH_ASYNC_0100
+ * @tc.name fileIO_test_stream_flush_async_002
+ * @tc.desc Test the flush() interface of class Stream. Promise.
+ * Refresh the file stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+
+ it('fileIO_test_stream_flush_async_002', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_flush_async_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+
+ try {
+ expect(sr !== null).assertTrue();
+ await sr.flush(1);
+ expect(false).assertTrue();
+ } catch (e) {
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_stream_flush_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+});
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/class_stream/read.test.js b/storage/storagefileiov9jstest/src/main/js/test/class_stream/read.test.js
similarity index 96%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/class_stream/read.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/class_stream/read.test.js
index 0817d3f1480abccf4ce0f677b2b70bb7158a38bd..9b9299e789cf09a5884342281f58655a7ea4cdd1 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/class_stream/read.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/class_stream/read.test.js
@@ -1,909 +1,909 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import {
- fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect,
-} from '../Common';
-
-export default function fileIOStreamRead() {
-describe('fileIO_fs_stream_read', function () {
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_SYNC_0000
- * @tc.name fileIO_test_stream_read_sync_000
- * @tc.desc Test the readSync() interface of class Stream.
- * Create a file stream in r+ mode, reading data from this stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_stream_read_sync_000', 0, async function () {
- let fpath = await nextFileName('fileIO_test_stream_read_sync_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let readLen1 = sr.readSync(new ArrayBuffer(16));
- expect(readLen1 == FILE_CONTENT.length).assertTrue();
- let readLen2 = sr.readSync(new ArrayBuffer(8));
- expect(readLen2 == 0).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_stream_read_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_SYNC_0100
- * @tc.name fileIO_test_stream_read_sync_001
- * @tc.desc Test the readSync() interface of class Stream.
- * Create a file stream in r+ mode, reading data with length = 2.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_read_sync_001', 0, async function () {
- let fpath = await nextFileName('fileIO_test_stream_read_sync_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let readLen = sr.readSync(new ArrayBuffer(4096), { length: 2 });
- expect(readLen == 2).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_stream_read_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_SYNC_0200
- * @tc.name fileIO_test_stream_read_sync_002
- * @tc.desc Test the readSync() interface of class Stream.
- * Create a file stream in r+ mode, reading data with offset = 2.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_read_sync_002', 0, async function () {
- let fpath = await nextFileName('fileIO_test_stream_read_sync_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let readLen = sr.readSync(new ArrayBuffer(4096), { offset: 2 });
- expect(readLen == FILE_CONTENT.length - 2).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_stream_read_sync_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_SYNC_0300
- * @tc.name fileIO_test_stream_read_sync_003
- * @tc.desc Test the readSync() interface of class Stream.
- * Create a file stream in r+ mode, reading data with offset = 1 and length = 11.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_read_sync_003', 0, async function () {
- let fpath = await nextFileName('fileIO_test_stream_read_sync_003');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let readLen = sr.readSync(new ArrayBuffer(4096), {
- offset: 1,
- length: FILE_CONTENT.length
- });
- expect(readLen == FILE_CONTENT.length - 1).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_stream_read_sync_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_SYNC_0400
- * @tc.name fileIO_test_stream_read_sync_004
- * @tc.desc Test the readSync() interface of class Stream.
- * Read data with invalid type of parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_read_sync_004', 0, async function () {
- let fpath = await nextFileName('fileIO_test_stream_read_sync_004');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let sr = fileIO.createStreamSync(fpath, 'r+');
-
- try {
- expect(sr !== null).assertTrue();
- sr.readSync("");
- expect(false).assertTrue();
- } catch (e) {
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_stream_read_sync_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_SYNC_0500
- * @tc.name fileIO_test_stream_read_sync_005
- * @tc.desc Test the readSync() interface of class Stream.
- * Read data with invalid length > size of ArrayBuffer(4096).
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_read_sync_005', 0, async function () {
- let fpath = await nextFileName('fileIO_test_stream_read_sync_005');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let sr = fileIO.createStreamSync(fpath, 'r+');
- const invalidLength = 4097;
-
- try {
- expect(sr !== null).assertTrue();
- sr.readSync(new ArrayBuffer(4096), { length: invalidLength });
- expect(false).assertTrue();
- } catch (e) {
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_stream_read_sync_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_SYNC_0600
- * @tc.name fileIO_test_stream_read_sync_006
- * @tc.desc Test the readSync() interface of class Stream.
- * Read data with invalid offset = -1.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_read_sync_006', 0, async function () {
- let fpath = await nextFileName('fileIO_test_stream_read_sync_006');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let sr = fileIO.createStreamSync(fpath, 'r+');
- const invalidOffset = -1;
-
- try {
- expect(sr !== null).assertTrue();
- sr.readSync(new ArrayBuffer(4096), { offset: invalidOffset });
- expect(false).assertTrue();
- } catch (e) {
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_stream_read_sync_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_SYNC_0700
- * @tc.name fileIO_test_stream_read_sync_007
- * @tc.desc Test the readSync() interface of class Stream.
- * Undefined option arguments, use default options.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_read_sync_007', 3, async function () {
- let fpath = await nextFileName('fileIO_test_stream_read_sync_007');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let readLen1 = sr.readSync(new ArrayBuffer(16), undefined);
- expect(readLen1 == FILE_CONTENT.length).assertTrue();
- let readLen2 = sr.readSync(new ArrayBuffer(8), undefined);
- expect(readLen2 == 0).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_stream_read_sync_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_SYNC_0800
- * @tc.name fileIO_test_stream_read_sync_008
- * @tc.desc Test the readSync() interface of class Stream.
- * Undefined option arguments, use default options.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_read_sync_008', 3, async function () {
- let fpath = await nextFileName('fileIO_test_stream_read_sync_008');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let readLen1 = sr.readSync(new ArrayBuffer(16), {
- offset: undefined,
- length: undefined
- });
- expect(readLen1 == FILE_CONTENT.length).assertTrue();
- let readLen2 = sr.readSync(new ArrayBuffer(8), {
- offset: undefined,
- length: undefined
- });
- expect(readLen2 == 0).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_stream_read_sync_008 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_0000
- * @tc.name fileIO_test_stream_read_async_000
- * @tc.desc Test read() interface, Promise.
- * Create a file stream in r+ mode, reading data from this stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 1
- * @tc.require
- */
- it('fileIO_test_stream_read_async_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_read_async_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let readLen1 = await sr.read(new ArrayBuffer(16));
- expect(readLen1 == FILE_CONTENT.length).assertTrue();
- let readLen2 = await sr.read(new ArrayBuffer(8));
- expect(readLen2 == 0).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_stream_read_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_0100
- * @tc.name fileIO_test_stream_read_async_001
- * @tc.desc Test read() interface, Callback.
- * Create a file stream in r+ mode, reading data from this stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 1
- * @tc.require
- */
- it('fileIO_test_stream_read_async_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_read_async_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- sr.read(new ArrayBuffer(16), (err, readLen1) => {
- if (err) {
- console.log('fileIO_test_stream_read_async_001 error package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(readLen1 == FILE_CONTENT.length).assertTrue();
- sr.read(new ArrayBuffer(8), (err, readLen2) => {
- if (err) {
- console.log('fileIO_test_stream_read_async_001 error package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(readLen2 == 0).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- });
- });
- } catch (e) {
- console.log('fileIO_test_stream_read_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_0200
- * @tc.name fileIO_test_stream_read_async_002
- * @tc.desc Test the read() interface of class Stream. Promise.
- * Create a file stream in r+ mode, reading data with length = 5.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_read_async_002', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_read_async_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let readLen = await sr.read(new ArrayBuffer(4096), {
- length: 5
- });
- expect(readLen == 5).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_stream_read_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_0300
- * @tc.name fileIO_test_stream_read_async_003
- * @tc.desc Test the read() interface of class Stream. Callback.
- * Create a file stream in r+ mode, reading data with length = 5.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_read_async_003', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_read_async_003');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- sr.read(new ArrayBuffer(4096), {
- length: 5
- }, (err, readLen) => {
- if (err) {
- console.log('fileIO_test_stream_read_async_003 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(readLen == 5).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_stream_read_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_0400
- * @tc.name fileIO_test_stream_read_async_004
- * @tc.desc Test the read() interface of class Stream. Promise.
- * Create a file stream in r+ mode, reading data with offset = 5.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_read_async_004', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_read_async_004');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let readLen = await sr.read(new ArrayBuffer(4096), {
- offset: 5
- });
- expect(readLen == FILE_CONTENT.length - 5).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_stream_read_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_0500
- * @tc.name fileIO_test_stream_read_async_005
- * @tc.desc Test the read() interface of class Stream. Callback.
- * Create a file stream in r+ mode, reading data with offset = 5.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_read_async_005', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_read_async_005');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- sr.read(new ArrayBuffer(4096), {
- offset: 5
- }, (err, readLen) => {
- if (err) {
- console.log('fileIO_test_stream_read_async_005 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(readLen == FILE_CONTENT.length - 5).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_stream_read_async_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_0600
- * @tc.name fileIO_test_stream_read_async_006
- * @tc.desc Test the read() interface of class Stream. Promise.
- * Read data with invalid length > size of ArrayBuffer(4096).
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_read_async_006', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_read_async_006');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let sr = fileIO.createStreamSync(fpath, 'r+');
-
- try {
- expect(sr !== null).assertTrue();
- const invalidLength = 4097;
- await sr.read(new ArrayBuffer(4096), { length: invalidLength });
- expect(false).assertTrue();
- } catch (e) {
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_stream_read_async_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_0700
- * @tc.name fileIO_test_stream_read_async_007
- * @tc.desc Test the read() interface of class Stream. Callback.
- * Read data with invalid offset = -1.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_read_async_007', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_read_async_007');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let sr = fileIO.createStreamSync(fpath, 'r+');
-
- try {
- expect(sr !== null).assertTrue();
- const invalidOffset = -1;
- sr.read(new ArrayBuffer(4096), {
- offset: invalidOffset
- }, (err) => {
- expect(false).assertTrue();
- });
- } catch (e) {
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_stream_read_async_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_0800
- * @tc.name fileIO_test_stream_read_async_008
- * @tc.desc Test the read() interface of class Stream. Promise.
- * Create a file stream in r+ mode, reading data with offset = 1 and length = 11.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_read_async_008', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_read_async_008');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let readLen = await sr.read(new ArrayBuffer(4096), {
- offset: 1,
- length: FILE_CONTENT.length
- });
- expect(readLen == FILE_CONTENT.length - 1).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_stream_read_async_008 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_0900
- * @tc.name fileIO_test_stream_read_async_009
- * @tc.desc Test the read() interface of class Stream. Callback.
- * Create a file stream in r+ mode, reading data with offset = 1 and length = 11.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_read_async_009', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_read_async_009');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- sr.read(new ArrayBuffer(4096), {
- offset: 1,
- length: FILE_CONTENT.length
- }, (err, readLen) => {
- if (err) {
- console.log('fileIO_test_stream_read_async_009 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(readLen == FILE_CONTENT.length - 1).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_stream_read_async_009 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_1000
- * @tc.name fileIO_test_stream_read_async_010
- * @tc.desc Test the read() interface of class Stream. Promise.
- * Create a file stream in r+ mode, reading data with empty option.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_read_async_010', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_read_async_010');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let readLen = await sr.read(new ArrayBuffer(4096), {});
- expect(readLen == FILE_CONTENT.length).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_stream_read_async_010 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_1100
- * @tc.name fileIO_test_stream_read_async_011
- * @tc.desc Test the read() interface of class Stream. Callback.
- * Create a file stream in r+ mode, reading data with empty option.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_read_async_011', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_read_async_011');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- sr.read(new ArrayBuffer(4096), {
- }, (err, readLen) => {
- if (err) {
- console.log('fileIO_test_stream_read_async_011 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(readLen == FILE_CONTENT.length).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_stream_read_async_011 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_1200
- * @tc.name fileIO_test_stream_read_async_012
- * @tc.desc Test the read() interface of class Stream. Promise. Missing parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_read_async_012', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_read_async_012');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let sr = fileIO.createStreamSync(fpath, 'r+');
-
- try {
- expect(sr !== null).assertTrue();
- await sr.read();
- expect(false).assertTrue();
- } catch (e) {
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_stream_read_async_012 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_1300
- * @tc.name fileIO_test_stream_read_async_013
- * @tc.desc Test the read() interface of class Stream. Promise.
- * Read data with invalid type of parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_read_async_013', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_read_async_013');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let sr = fileIO.createStreamSync(fpath, 'r+');
-
- try {
- expect(sr !== null).assertTrue();
- await sr.read("");
- expect(false).assertTrue();
- } catch (e) {
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_stream_read_async_013 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_1400
- * @tc.name fileIO_test_stream_read_async_014
- * @tc.desc Test the read() interface of class Stream. Callback.
- * Read data with invalid type of parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_read_async_014', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_read_async_014');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let sr = fileIO.createStreamSync(fpath, 'r+');
-
- try {
- expect(sr !== null).assertTrue();
- sr.read("", (err) => {
- expect(false).assertTrue();
- });
- } catch (e) {
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_stream_read_async_014 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_1500
- * @tc.name fileIO_test_stream_read_async_015
- * @tc.desc Test the read() interface of class Stream. Promise.
- * Undefined option arguments, use default options.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_read_async_015', 3, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_read_async_015');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let readLen1 = await sr.read(new ArrayBuffer(16), undefined);
- expect(readLen1 == FILE_CONTENT.length).assertTrue();
- let readLen2 = await sr.read(new ArrayBuffer(8), undefined);
- expect(readLen2 == 0).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_stream_read_async_015 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_1600
- * @tc.name fileIO_test_stream_read_async_016
- * @tc.desc Test the read() interface of class Stream. Callback.
- * Undefined option arguments, use default options.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_read_async_016', 3, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_read_async_016');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- sr.read(new ArrayBuffer(16), undefined, (err, readLen1) => {
- if (err) {
- console.log('fileIO_test_stream_read_async_016 error package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(readLen1 == FILE_CONTENT.length).assertTrue();
- sr.read(new ArrayBuffer(8), undefined, (err, readLen2) => {
- if (err) {
- console.log('fileIO_test_stream_read_async_016 error package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(readLen2 == 0).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- });
- });
- } catch (e) {
- console.log('fileIO_test_stream_read_async_016 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_1700
- * @tc.name fileIO_test_stream_read_async_017
- * @tc.desc Test the read() interface of class Stream. Promise.
- * Undefined option arguments, use default options.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_read_async_017', 3, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_read_async_017');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let readLen1 = await sr.read(new ArrayBuffer(16), {
- offset: undefined,
- length: undefined
- });
- expect(readLen1 == FILE_CONTENT.length).assertTrue();
- let readLen2 = await sr.read(new ArrayBuffer(8), {
- offset: undefined,
- length: undefined
- });
- expect(readLen2 == 0).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_stream_read_async_017 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_1800
- * @tc.name fileIO_test_stream_read_async_018
- * @tc.desc Test the read() interface of class Stream. Callback.
- * Undefined option arguments, use default options.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_read_async_018', 3, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_read_async_018');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- sr.read(new ArrayBuffer(4096), {
- offset: undefined,
- length: undefined
- }, (err, readLen1) => {
- if (err) {
- console.log('fileIO_test_stream_read_async_018 error package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(readLen1 == FILE_CONTENT.length).assertTrue();
- sr.read(new ArrayBuffer(8), {
- offset: undefined,
- length: undefined
- }, (err, readLen2) => {
- if (err) {
- console.log('fileIO_test_stream_read_async_018 error package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(readLen2 == 0).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- });
- });
- } catch (e) {
- console.log('fileIO_test_stream_read_async_018 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-});
-}
+/*
+ * Copyright (C) 2023 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import {
+ fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect,
+} from '../Common';
+
+export default function fileIOStreamRead() {
+describe('fileIO_fs_stream_read', function () {
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_SYNC_0000
+ * @tc.name fileIO_test_stream_read_sync_000
+ * @tc.desc Test the readSync() interface of class Stream.
+ * Create a file stream in r+ mode, reading data from this stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_sync_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_read_sync_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let readLen1 = sr.readSync(new ArrayBuffer(16));
+ expect(readLen1 == FILE_CONTENT.length).assertTrue();
+ let readLen2 = sr.readSync(new ArrayBuffer(8));
+ expect(readLen2 == 0).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_stream_read_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_SYNC_0100
+ * @tc.name fileIO_test_stream_read_sync_001
+ * @tc.desc Test the readSync() interface of class Stream.
+ * Create a file stream in r+ mode, reading data with length = 2.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_sync_001', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_read_sync_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let readLen = sr.readSync(new ArrayBuffer(4096), { length: 2 });
+ expect(readLen == 2).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_stream_read_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_SYNC_0200
+ * @tc.name fileIO_test_stream_read_sync_002
+ * @tc.desc Test the readSync() interface of class Stream.
+ * Create a file stream in r+ mode, reading data with offset = 2.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_sync_002', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_read_sync_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let readLen = sr.readSync(new ArrayBuffer(4096), { offset: 2 });
+ expect(readLen == FILE_CONTENT.length - 2).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_stream_read_sync_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_SYNC_0300
+ * @tc.name fileIO_test_stream_read_sync_003
+ * @tc.desc Test the readSync() interface of class Stream.
+ * Create a file stream in r+ mode, reading data with offset = 1 and length = 11.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_sync_003', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_read_sync_003');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let readLen = sr.readSync(new ArrayBuffer(4096), {
+ offset: 1,
+ length: FILE_CONTENT.length
+ });
+ expect(readLen == FILE_CONTENT.length - 1).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_stream_read_sync_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_SYNC_0400
+ * @tc.name fileIO_test_stream_read_sync_004
+ * @tc.desc Test the readSync() interface of class Stream.
+ * Read data with invalid type of parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_sync_004', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_read_sync_004');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+
+ try {
+ expect(sr !== null).assertTrue();
+ sr.readSync("");
+ expect(false).assertTrue();
+ } catch (e) {
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_stream_read_sync_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_SYNC_0500
+ * @tc.name fileIO_test_stream_read_sync_005
+ * @tc.desc Test the readSync() interface of class Stream.
+ * Read data with invalid length > size of ArrayBuffer(4096).
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_sync_005', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_read_sync_005');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ const invalidLength = 4097;
+
+ try {
+ expect(sr !== null).assertTrue();
+ sr.readSync(new ArrayBuffer(4096), { length: invalidLength });
+ expect(false).assertTrue();
+ } catch (e) {
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_stream_read_sync_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_SYNC_0600
+ * @tc.name fileIO_test_stream_read_sync_006
+ * @tc.desc Test the readSync() interface of class Stream.
+ * Read data with invalid offset = -1.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_sync_006', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_read_sync_006');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ const invalidOffset = -1;
+
+ try {
+ expect(sr !== null).assertTrue();
+ sr.readSync(new ArrayBuffer(4096), { offset: invalidOffset });
+ expect(false).assertTrue();
+ } catch (e) {
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_stream_read_sync_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_SYNC_0700
+ * @tc.name fileIO_test_stream_read_sync_007
+ * @tc.desc Test the readSync() interface of class Stream.
+ * Undefined option arguments, use default options.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_sync_007', 3, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_read_sync_007');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let readLen1 = sr.readSync(new ArrayBuffer(16), undefined);
+ expect(readLen1 == FILE_CONTENT.length).assertTrue();
+ let readLen2 = sr.readSync(new ArrayBuffer(8), undefined);
+ expect(readLen2 == 0).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_stream_read_sync_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_SYNC_0800
+ * @tc.name fileIO_test_stream_read_sync_008
+ * @tc.desc Test the readSync() interface of class Stream.
+ * Undefined option arguments, use default options.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_sync_008', 3, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_read_sync_008');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let readLen1 = sr.readSync(new ArrayBuffer(16), {
+ offset: undefined,
+ length: undefined
+ });
+ expect(readLen1 == FILE_CONTENT.length).assertTrue();
+ let readLen2 = sr.readSync(new ArrayBuffer(8), {
+ offset: undefined,
+ length: undefined
+ });
+ expect(readLen2 == 0).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_stream_read_sync_008 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_0000
+ * @tc.name fileIO_test_stream_read_async_000
+ * @tc.desc Test read() interface, Promise.
+ * Create a file stream in r+ mode, reading data from this stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 1
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_async_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_read_async_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let readLen1 = await sr.read(new ArrayBuffer(16));
+ expect(readLen1 == FILE_CONTENT.length).assertTrue();
+ let readLen2 = await sr.read(new ArrayBuffer(8));
+ expect(readLen2 == 0).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_stream_read_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_0100
+ * @tc.name fileIO_test_stream_read_async_001
+ * @tc.desc Test read() interface, Callback.
+ * Create a file stream in r+ mode, reading data from this stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 1
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_async_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_read_async_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ sr.read(new ArrayBuffer(16), (err, readLen1) => {
+ if (err) {
+ console.log('fileIO_test_stream_read_async_001 error package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(readLen1 == FILE_CONTENT.length).assertTrue();
+ sr.read(new ArrayBuffer(8), (err, readLen2) => {
+ if (err) {
+ console.log('fileIO_test_stream_read_async_001 error package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(readLen2 == 0).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ });
+ } catch (e) {
+ console.log('fileIO_test_stream_read_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_0200
+ * @tc.name fileIO_test_stream_read_async_002
+ * @tc.desc Test the read() interface of class Stream. Promise.
+ * Create a file stream in r+ mode, reading data with length = 5.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_async_002', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_read_async_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let readLen = await sr.read(new ArrayBuffer(4096), {
+ length: 5
+ });
+ expect(readLen == 5).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_stream_read_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_0300
+ * @tc.name fileIO_test_stream_read_async_003
+ * @tc.desc Test the read() interface of class Stream. Callback.
+ * Create a file stream in r+ mode, reading data with length = 5.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_async_003', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_read_async_003');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ sr.read(new ArrayBuffer(4096), {
+ length: 5
+ }, (err, readLen) => {
+ if (err) {
+ console.log('fileIO_test_stream_read_async_003 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(readLen == 5).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_stream_read_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_0400
+ * @tc.name fileIO_test_stream_read_async_004
+ * @tc.desc Test the read() interface of class Stream. Promise.
+ * Create a file stream in r+ mode, reading data with offset = 5.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_async_004', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_read_async_004');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let readLen = await sr.read(new ArrayBuffer(4096), {
+ offset: 5
+ });
+ expect(readLen == FILE_CONTENT.length - 5).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_stream_read_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_0500
+ * @tc.name fileIO_test_stream_read_async_005
+ * @tc.desc Test the read() interface of class Stream. Callback.
+ * Create a file stream in r+ mode, reading data with offset = 5.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_async_005', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_read_async_005');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ sr.read(new ArrayBuffer(4096), {
+ offset: 5
+ }, (err, readLen) => {
+ if (err) {
+ console.log('fileIO_test_stream_read_async_005 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(readLen == FILE_CONTENT.length - 5).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_stream_read_async_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_0600
+ * @tc.name fileIO_test_stream_read_async_006
+ * @tc.desc Test the read() interface of class Stream. Promise.
+ * Read data with invalid length > size of ArrayBuffer(4096).
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_async_006', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_read_async_006');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+
+ try {
+ expect(sr !== null).assertTrue();
+ const invalidLength = 4097;
+ await sr.read(new ArrayBuffer(4096), { length: invalidLength });
+ expect(false).assertTrue();
+ } catch (e) {
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_stream_read_async_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_0700
+ * @tc.name fileIO_test_stream_read_async_007
+ * @tc.desc Test the read() interface of class Stream. Callback.
+ * Read data with invalid offset = -1.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_async_007', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_read_async_007');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+
+ try {
+ expect(sr !== null).assertTrue();
+ const invalidOffset = -1;
+ sr.read(new ArrayBuffer(4096), {
+ offset: invalidOffset
+ }, (err) => {
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_stream_read_async_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_0800
+ * @tc.name fileIO_test_stream_read_async_008
+ * @tc.desc Test the read() interface of class Stream. Promise.
+ * Create a file stream in r+ mode, reading data with offset = 1 and length = 11.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_async_008', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_read_async_008');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let readLen = await sr.read(new ArrayBuffer(4096), {
+ offset: 1,
+ length: FILE_CONTENT.length
+ });
+ expect(readLen == FILE_CONTENT.length - 1).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_stream_read_async_008 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_0900
+ * @tc.name fileIO_test_stream_read_async_009
+ * @tc.desc Test the read() interface of class Stream. Callback.
+ * Create a file stream in r+ mode, reading data with offset = 1 and length = 11.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_async_009', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_read_async_009');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ sr.read(new ArrayBuffer(4096), {
+ offset: 1,
+ length: FILE_CONTENT.length
+ }, (err, readLen) => {
+ if (err) {
+ console.log('fileIO_test_stream_read_async_009 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(readLen == FILE_CONTENT.length - 1).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_stream_read_async_009 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_1000
+ * @tc.name fileIO_test_stream_read_async_010
+ * @tc.desc Test the read() interface of class Stream. Promise.
+ * Create a file stream in r+ mode, reading data with empty option.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_async_010', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_read_async_010');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let readLen = await sr.read(new ArrayBuffer(4096), {});
+ expect(readLen == FILE_CONTENT.length).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_stream_read_async_010 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_1100
+ * @tc.name fileIO_test_stream_read_async_011
+ * @tc.desc Test the read() interface of class Stream. Callback.
+ * Create a file stream in r+ mode, reading data with empty option.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_async_011', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_read_async_011');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ sr.read(new ArrayBuffer(4096), {
+ }, (err, readLen) => {
+ if (err) {
+ console.log('fileIO_test_stream_read_async_011 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(readLen == FILE_CONTENT.length).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_stream_read_async_011 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_1200
+ * @tc.name fileIO_test_stream_read_async_012
+ * @tc.desc Test the read() interface of class Stream. Promise. Missing parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_async_012', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_read_async_012');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+
+ try {
+ expect(sr !== null).assertTrue();
+ await sr.read();
+ expect(false).assertTrue();
+ } catch (e) {
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_stream_read_async_012 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_1300
+ * @tc.name fileIO_test_stream_read_async_013
+ * @tc.desc Test the read() interface of class Stream. Promise.
+ * Read data with invalid type of parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_async_013', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_read_async_013');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+
+ try {
+ expect(sr !== null).assertTrue();
+ await sr.read("");
+ expect(false).assertTrue();
+ } catch (e) {
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_stream_read_async_013 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_1400
+ * @tc.name fileIO_test_stream_read_async_014
+ * @tc.desc Test the read() interface of class Stream. Callback.
+ * Read data with invalid type of parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_async_014', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_read_async_014');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+
+ try {
+ expect(sr !== null).assertTrue();
+ sr.read("", (err) => {
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_stream_read_async_014 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_1500
+ * @tc.name fileIO_test_stream_read_async_015
+ * @tc.desc Test the read() interface of class Stream. Promise.
+ * Undefined option arguments, use default options.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_async_015', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_read_async_015');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let readLen1 = await sr.read(new ArrayBuffer(16), undefined);
+ expect(readLen1 == FILE_CONTENT.length).assertTrue();
+ let readLen2 = await sr.read(new ArrayBuffer(8), undefined);
+ expect(readLen2 == 0).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_stream_read_async_015 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_1600
+ * @tc.name fileIO_test_stream_read_async_016
+ * @tc.desc Test the read() interface of class Stream. Callback.
+ * Undefined option arguments, use default options.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_async_016', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_read_async_016');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ sr.read(new ArrayBuffer(16), undefined, (err, readLen1) => {
+ if (err) {
+ console.log('fileIO_test_stream_read_async_016 error package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(readLen1 == FILE_CONTENT.length).assertTrue();
+ sr.read(new ArrayBuffer(8), undefined, (err, readLen2) => {
+ if (err) {
+ console.log('fileIO_test_stream_read_async_016 error package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(readLen2 == 0).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ });
+ } catch (e) {
+ console.log('fileIO_test_stream_read_async_016 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_1700
+ * @tc.name fileIO_test_stream_read_async_017
+ * @tc.desc Test the read() interface of class Stream. Promise.
+ * Undefined option arguments, use default options.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_async_017', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_read_async_017');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let readLen1 = await sr.read(new ArrayBuffer(16), {
+ offset: undefined,
+ length: undefined
+ });
+ expect(readLen1 == FILE_CONTENT.length).assertTrue();
+ let readLen2 = await sr.read(new ArrayBuffer(8), {
+ offset: undefined,
+ length: undefined
+ });
+ expect(readLen2 == 0).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_stream_read_async_017 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_READ_ASYNC_1800
+ * @tc.name fileIO_test_stream_read_async_018
+ * @tc.desc Test the read() interface of class Stream. Callback.
+ * Undefined option arguments, use default options.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_read_async_018', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_read_async_018');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ sr.read(new ArrayBuffer(4096), {
+ offset: undefined,
+ length: undefined
+ }, (err, readLen1) => {
+ if (err) {
+ console.log('fileIO_test_stream_read_async_018 error package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(readLen1 == FILE_CONTENT.length).assertTrue();
+ sr.read(new ArrayBuffer(8), {
+ offset: undefined,
+ length: undefined
+ }, (err, readLen2) => {
+ if (err) {
+ console.log('fileIO_test_stream_read_async_018 error package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(readLen2 == 0).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ });
+ } catch (e) {
+ console.log('fileIO_test_stream_read_async_018 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+});
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/class_stream/write.test.js b/storage/storagefileiov9jstest/src/main/js/test/class_stream/write.test.js
similarity index 96%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/class_stream/write.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/class_stream/write.test.js
index 797bb8fb1d9f2cb5dc5e41b71794af6f5deae954..c6d224ef36fad1548d74ae8724b333bf35f2dd9f 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/class_stream/write.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/class_stream/write.test.js
@@ -1,1233 +1,1233 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import {
- fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect,
-} from '../Common';
-
-export default function fileIOStreamWrite() {
-describe('fileIO_fs_stream_write', function () {
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_0000
- * @tc.name fileIO_test_stream_write_sync_000
- * @tc.desc Test the writeSync() interface of class Stream.
- * Create a file stream in r+ mode, writing an ArrayBuffer.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_stream_write_sync_000', 0, async function () {
- let fpath = await nextFileName('fileIO_test_stream_write_sync_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let bytesWritten1 = sr.writeSync(FILE_CONTENT);
- expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
- let bytesWritten2 = sr.writeSync(new ArrayBuffer(FILE_CONTENT.length));
- expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
- let readLen = sr.readSync(new ArrayBuffer(4096), { offset: 0 });
- expect(readLen == FILE_CONTENT.length * 2).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_stream_write_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_0100
- * @tc.name fileIO_test_stream_write_sync_001
- * @tc.desc Test the writeSync() interface of class Stream.
- * Create a file stream in r+ mode, writing a string.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_sync_001', 0, async function () {
- let fpath = await nextFileName('fileIO_test_stream_write_sync_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let bytesWritten = sr.writeSync(FILE_CONTENT);
- expect(bytesWritten == FILE_CONTENT.length).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_stream_write_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_0200
- * @tc.name fileIO_test_stream_write_sync_002
- * @tc.desc Test the writeSync() interface of class Stream.
- * Create a file stream in r+ mode, writing a string with offset = 1.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_sync_002', 0, async function () {
- let fpath = await nextFileName('fileIO_test_stream_write_sync_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let bytesWritten = sr.writeSync(FILE_CONTENT, { offset: 1 });
- expect(bytesWritten == FILE_CONTENT.length).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_stream_write_sync_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_0300
- * @tc.name fileIO_test_stream_write_sync_003
- * @tc.desc Test the writeSync() interface of class Stream.
- * Write a string with invalide offset = -1.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_sync_003', 0, async function () {
- let fpath = await nextFileName('fileIO_test_stream_write_sync_003');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let sr = fileIO.createStreamSync(fpath, 'r+');
- const invalidOffset = -1;
-
- try {
- expect(sr !== null).assertTrue();
- sr.writeSync(new ArrayBuffer(4096), { offset: invalidOffset });
- expect(false).assertTrue();
- } catch (e) {
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_stream_write_sync_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_0400
- * @tc.name fileIO_test_stream_write_sync_004
- * @tc.desc Test the writeSync() interface of class Stream.
- * Create a file stream in r+ mode, writing a string with encoding = 'utf-8'.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_sync_004', 0, async function () {
- let fpath = await nextFileName('fileIO_test_stream_write_sync_004');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let bytesWritten = sr.writeSync(FILE_CONTENT, { encoding: 'utf-8' });
- expect(bytesWritten == FILE_CONTENT.length).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_stream_write_sync_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_0500
- * @tc.name fileIO_test_stream_write_sync_005
- * @tc.desc Test the writeSync() interface of class Stream.
- * Create a file stream in r+ mode, writing a string with length = 5.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_sync_005', 0, async function () {
- let fpath = await nextFileName('fileIO_test_stream_write_sync_005');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let bytesWritten = sr.writeSync(FILE_CONTENT, { length: 5 });
- expect(bytesWritten == 5).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_stream_write_sync_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_0600
- * @tc.name fileIO_test_stream_write_sync_006
- * @tc.desc Test the writeSync() interface of class Stream.
- * Write an ArrayBuffer with invalid length > size of ArrayBuffer(4096).
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_sync_006', 0, async function () {
- let fpath = await nextFileName('fileIO_test_stream_write_sync_006');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let sr = fileIO.createStreamSync(fpath, 'r+');
-
- try {
- expect(sr !== null).assertTrue();
- const invalidLength = 4097;
- sr.writeSync(new ArrayBuffer(4096), { length: invalidLength });
- expect(false).assertTrue();
- } catch (e) {
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_stream_write_sync_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_0700
- * @tc.name fileIO_test_stream_write_sync_007
- * @tc.desc Test the writeSync() interface of class Stream.
- * Write a string with invalid length = 9999.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_sync_007', 0, async function () {
- let fpath = await nextFileName('fileIO_test_stream_write_sync_007');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let sr = fileIO.createStreamSync(fpath, 'r+');
- const invalidLength = 9999;
-
- try {
- expect(sr !== null).assertTrue();
- sr.writeSync(FILE_CONTENT, { length: invalidLength });
- expect(false).assertTrue();
- } catch (e) {
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_stream_write_sync_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_0800
- * @tc.name fileIO_test_stream_write_sync_008
- * @tc.desc Test the writeSync() interface of class Stream.
- * Create a file stream in r+ mode, writing an ArrayBuffer with offset = 1, length = 4096 and encoding = 'utf-8'.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_sync_008', 0, async function () {
- let fpath = await nextFileName('fileIO_test_stream_write_sync_008');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let bytesWritten = sr.writeSync(new ArrayBuffer(4096), {
- offset: 1,
- length: 4096,
- encoding: 'utf-8'
- });
- expect(bytesWritten == 4096).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_stream_write_sync_008 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_0900
- * @tc.name fileIO_test_stream_write_sync_009
- * @tc.desc Test the writeSync() interface of class Stream.
- * Create a file stream in r+ mode, writing a string with offset = 1, length = 11 and encoding = 'utf-8'.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_sync_009', 0, async function () {
- let fpath = await nextFileName('fileIO_test_stream_write_sync_009');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let bytesWritten = sr.writeSync(FILE_CONTENT, {
- offset: 1,
- length: FILE_CONTENT.length,
- encoding: 'utf-8'
- });
- expect(bytesWritten == FILE_CONTENT.length).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_stream_write_sync_009 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_1000
- * @tc.name fileIO_test_stream_write_sync_010
- * @tc.desc Test the writeSync() interface of class Stream.
- * Create a file stream in r+ mode, writing a string with empty option.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_sync_010', 0, async function () {
- let fpath = await nextFileName('fileIO_test_stream_write_sync_010');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let bytesWritten = sr.writeSync(FILE_CONTENT, {});
- expect(bytesWritten == FILE_CONTENT.length).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_stream_write_sync_010 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_1100
- * @tc.name fileIO_test_stream_write_sync_011
- * @tc.desc Test the writeSync() interface of class Stream.
- * There are no parameters.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_sync_011', 0, async function () {
- let fpath = await nextFileName('fileIO_test_stream_write_sync_011');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let sr = fileIO.createStreamSync(fpath, 'r+');
-
- try {
- expect(sr !== null).assertTrue();
- sr.writeSync();
- expect(false).assertTrue();
- } catch (e) {
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_stream_write_sync_011 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_1200
- * @tc.name fileIO_test_stream_write_sync_012
- * @tc.desc Test the writeSync() interface of class Stream.
- * Undefined option arguments, use default options.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_sync_012', 3, async function () {
- let fpath = await nextFileName('fileIO_test_stream_write_sync_012');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let bytesWritten = sr.writeSync(new ArrayBuffer(4096), undefined);
- expect(bytesWritten == 4096).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_stream_write_sync_012 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_1300
- * @tc.name fileIO_test_stream_write_sync_013
- * @tc.desc Test the writeSync() interface of class Stream.
- * Undefined option arguments, use default options.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_sync_013', 3, async function () {
- let fpath = await nextFileName('fileIO_test_stream_write_sync_013');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let bytesWritten = sr.writeSync(new ArrayBuffer(4096), {
- offset: undefined,
- length: undefined,
- encoding: undefined
- });
- expect(bytesWritten == 4096).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_stream_write_sync_013 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_0000
- * @tc.name fileIO_test_stream_write_async_000
- * @tc.desc Test the write() interface of class Stream. Promise.
- * Create a file stream in r+ mode, writing an ArrayBuffer.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 1
- * @tc.require
- */
- it('fileIO_test_stream_write_async_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_write_async_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let bytesWritten1 = await sr.write(FILE_CONTENT);
- expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
- let bytesWritten2 = await sr.write(new ArrayBuffer(FILE_CONTENT.length));
- expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
- let readLen = sr.readSync(new ArrayBuffer(4096), { offset: 0 });
- expect(readLen == FILE_CONTENT.length * 2).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_stream_write_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_0100
- * @tc.name fileIO_test_stream_write_async_001
- * @tc.desc Test the write() interface of class Stream. Callback.
- * Create a file stream in r+ mode, writing an ArrayBuffer.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 1
- * @tc.require
- */
- it('fileIO_test_stream_write_async_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_write_async_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- sr.write(FILE_CONTENT, (err, bytesWritten1) => {
- if (err) {
- console.log('fileIO_test_stream_write_async_001 err package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
- sr.write(new ArrayBuffer(FILE_CONTENT.length), (err, bytesWritten2) => {
- if (err) {
- console.log('fileIO_test_stream_write_async_001 err package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
- let readLen = sr.readSync(new ArrayBuffer(4096), { offset: 0 });
- expect(readLen == FILE_CONTENT.length * 2).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- });
- });
- } catch (e) {
- console.log('fileIO_test_stream_write_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_0200
- * @tc.name fileIO_test_stream_write_async_002
- * @tc.desc Test the write() interface of class Stream. Promise.
- * Create a file stream in r+ mode, writing a string.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_async_002', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_write_async_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let bytesWritten = await sr.write(FILE_CONTENT);
- expect(bytesWritten == FILE_CONTENT.length).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_stream_write_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_0300
- * @tc.name fileIO_test_stream_write_async_003
- * @tc.desc Test the write() interface of class Stream. Callback.
- * Create a file stream in r+ mode, writing a string.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_async_003', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_write_async_003');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- sr.write(FILE_CONTENT, (err, bytesWritten) => {
- if (err) {
- console.log('fileIO_test_stream_write_async_003 err package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(bytesWritten == FILE_CONTENT.length).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_stream_write_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_0400
- * @tc.name fileIO_test_stream_write_async_004
- * @tc.desc Test the write() interface of class Stream. Promise.
- * Create a file stream in r+ mode, writing a string with offset = 1.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_async_004', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_write_async_004');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let bytesWritten = await sr.write(FILE_CONTENT, { offset: 1 });
- expect(bytesWritten == FILE_CONTENT.length).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_stream_write_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_0500
- * @tc.name fileIO_test_stream_write_async_005
- * @tc.desc Test the write() interface of class Stream. Callback.
- * Create a file stream in r+ mode, writing a string with offset = 1.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_async_005', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_write_async_005');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- sr.write(FILE_CONTENT, {
- offset: 1
- }, (err, bytesWritten) => {
- if (err) {
- console.log('fileIO_test_stream_write_async_005 err package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(bytesWritten == FILE_CONTENT.length).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_stream_write_async_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_0600
- * @tc.name fileIO_test_stream_write_async_006
- * @tc.desc Test the write() interface of class Stream. Callback.
- * Write a string with invalide offset = -1.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_async_006', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_write_async_006');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let sr = fileIO.createStreamSync(fpath, 'r+');
- const invalidOffset = -1;
-
- try {
- expect(sr !== null).assertTrue();
- sr.write(new ArrayBuffer(4096), {
- offset: invalidOffset
- }, (err) => {
- expect(false).assertTrue();
- });
- } catch (e) {
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_stream_write_async_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_0700
- * @tc.name fileIO_test_stream_write_async_007
- * @tc.desc Test the write() interface of class Stream. Promise.
- * Create a file stream in r+ mode, writing a string with encoding = 'utf-8'.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_async_007', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_write_async_007');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let bytesWritten = await sr.write(FILE_CONTENT, { encoding: 'utf-8' });
- expect(bytesWritten == FILE_CONTENT.length).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_stream_write_async_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_0800
- * @tc.name fileIO_test_stream_write_async_008
- * @tc.desc Test the write() interface of class Stream. Promise.
- * Create a file stream in r+ mode, writing a string with encoding = 'utf-8'.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_async_008', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_write_async_008');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- sr.write(FILE_CONTENT, {
- encoding: 'utf-8'
- }, (err, bytesWritten) => {
- if (err) {
- console.log('fileIO_test_stream_write_async_008 err package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(bytesWritten == FILE_CONTENT.length).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_stream_write_async_008 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_0900
- * @tc.name fileIO_test_stream_write_async_009
- * @tc.desc Test the write() interface of class Stream. Promise.
- * Create a file stream in r+ mode, writing a string with length = 5.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_async_009', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_write_async_009');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let bytesWritten = await sr.write(FILE_CONTENT, { length: 5 });
- expect(bytesWritten == 5).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_stream_write_async_009 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_1000
- * @tc.name fileIO_test_stream_write_async_010
- * @tc.desc Test the write() interface of class Stream. Callback.
- * Create a file stream in r+ mode, writing a string with length = 5.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_async_010', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_write_async_010');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- sr.write(FILE_CONTENT, {
- length: 5
- }, (err, bytesWritten) => {
- if (err) {
- console.log('fileIO_test_stream_write_async_010 err package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(bytesWritten == 5).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_stream_write_async_010 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_1100
- * @tc.name fileIO_test_stream_write_async_011
- * @tc.desc Test the write() interface of class Stream. Callback.
- * Write an ArrayBuffer with invalid length > size of ArrayBuffer(4096).
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_async_011', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_write_async_011');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let sr = fileIO.createStreamSync(fpath, 'r+');
- const invalidLength = 4097;
-
- try {
- expect(sr !== null).assertTrue();
- sr.write(new ArrayBuffer(4096), {
- length: invalidLength
- }, (err) => {
- expect(false).assertTrue();
- });
- } catch (e) {
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_stream_write_async_011 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_1200
- * @tc.name fileIO_test_stream_write_async_012
- * @tc.desc Test the write() interface of class Stream. Callback.
- * Write a string with invalid length = 9999.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_async_012', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_write_async_012');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let sr = fileIO.createStreamSync(fpath, 'r+');
- const invalidLength = 9999;
-
- try {
- expect(sr !== null).assertTrue();
- sr.write(FILE_CONTENT, {
- length: invalidLength
- }, (err) => {
- expect(false).assertTrue();
- });
- } catch (e) {
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_stream_write_async_012 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_1300
- * @tc.name fileIO_test_stream_write_async_013
- * @tc.desc Test the write() interface of class Stream. Promise.
- * Create a file stream in r+ mode, writing an ArrayBuffer with offset = 1, length = 4096 and encoding = 'utf-8'.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_async_013', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_write_async_013');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let bytesWritten = await sr.write(new ArrayBuffer(4096), {
- offset: 1,
- length: 4096,
- encoding: 'utf-8'
- });
- expect(bytesWritten == 4096).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_stream_write_async_013 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_1400
- * @tc.name fileIO_test_stream_write_async_014
- * @tc.desc Test the write() interface of class Stream. Callback.
- * Create a file stream in r+ mode, writing an ArrayBuffer with offset = 1, length = 4096 and encoding = 'utf-8'.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_async_014', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_write_async_014');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- sr.write(new ArrayBuffer(4096), {
- offset: 1,
- length: 4096,
- encoding: 'utf-8'
- }, (err, bytesWritten) => {
- if (err) {
- console.log('fileIO_test_stream_write_async_014 err package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(bytesWritten == 4096).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_stream_write_async_014 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_1500
- * @tc.name fileIO_test_stream_write_async_015
- * @tc.desc Test the write() interface of class Stream. Promise.
- * Create a file stream in r+ mode, writing a string with offset = 1, length = 4096 and encoding = 'utf-8'.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_async_015', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_write_async_015');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let bytesWritten = await sr.write(FILE_CONTENT, {
- offset: 1,
- length: FILE_CONTENT.length,
- encoding: 'utf-8'
- });
- expect(bytesWritten == FILE_CONTENT.length).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_stream_write_async_015 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_1600
- * @tc.name fileIO_test_stream_write_async_016
- * @tc.desc Test the write() interface of class Stream. Callback.
- * Create a file stream in r+ mode, writing a string with offset = 1, length = 4096 and encoding = 'utf-8'.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_async_016', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_write_async_016');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- sr.write(FILE_CONTENT, {
- offset: 1,
- length: FILE_CONTENT.length,
- encoding: 'utf-8'
- }, (err, bytesWritten) => {
- if (err) {
- console.log('fileIO_test_stream_write_async_016 err package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(bytesWritten == FILE_CONTENT.length).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_stream_write_async_016 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_1700
- * @tc.name fileIO_test_stream_write_async_017
- * @tc.desc Test the write() interface of class Stream. Promise.
- * Create a file stream in r+ mode, writing a string with empty option.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_async_017', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_write_async_017');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let bytesWritten = await sr.write(FILE_CONTENT, {});
- expect(bytesWritten == FILE_CONTENT.length).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_stream_write_async_017 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_1800
- * @tc.name fileIO_test_stream_write_async_018
- * @tc.desc Test the write() interface of class Stream. Callback.
- * Create a file stream in r+ mode, writing a string with empty option.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_async_018', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_write_async_018');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- sr.write(FILE_CONTENT, {
- }, (err, bytesWritten) => {
- if (err) {
- console.log('fileIO_test_stream_write_async_018 err package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(bytesWritten == FILE_CONTENT.length).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_stream_write_async_018 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_1900
- * @tc.name fileIO_test_stream_write_async_019
- * @tc.desc Test the write() interface of class Stream. Promise.
- * There are no parameters.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_async_019', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_write_async_019');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let sr = fileIO.createStreamSync(fpath, 'r+');
-
- try {
- expect(sr !== null).assertTrue();
- await sr.write();
- expect(false).assertTrue();
- } catch (e) {
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_stream_write_async_019 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_2000
- * @tc.name fileIO_test_stream_write_async_020
- * @tc.desc Test the write() interface of class Stream. Promise.
- * Undefined option arguments, use default options.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_async_020', 3, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_write_async_020');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let bytesWritten1 = await sr.write(FILE_CONTENT, undefined);
- expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
- let bytesWritten2 = await sr.write(new ArrayBuffer(FILE_CONTENT.length), undefined);
- expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
- let readLen = sr.readSync(new ArrayBuffer(4096), { offset: 0 });
- expect(readLen == FILE_CONTENT.length * 2).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_stream_write_async_020 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_2100
- * @tc.name fileIO_test_stream_write_async_021
- * @tc.desc Test the write() interface of class Stream. Callback.
- * Undefined option arguments, use default options.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_async_021', 3, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_write_async_021');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- sr.write(FILE_CONTENT, undefined, (err, bytesWritten1) => {
- if (err) {
- console.log('fileIO_test_stream_write_async_021 err package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
- sr.write(new ArrayBuffer(FILE_CONTENT.length), undefined, (err, bytesWritten2) => {
- if (err) {
- console.log('fileIO_test_stream_write_async_021 err package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
- let readLen = sr.readSync(new ArrayBuffer(4096), { offset: 0 });
- expect(readLen == FILE_CONTENT.length * 2).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- });
- });
- } catch (e) {
- console.log('fileIO_test_stream_write_async_021 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_2200
- * @tc.name fileIO_test_stream_write_async_022
- * @tc.desc Test the write() interface of class Stream. Promise.
- * Undefined option arguments, use default options.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_async_022', 3, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_write_async_022');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- let bytesWritten1 = await sr.write(FILE_CONTENT, {
- offset: undefined,
- length: undefined,
- encoding: undefined
- });
- expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
- let bytesWritten2 = await sr.write(new ArrayBuffer(FILE_CONTENT.length), {
- offset: undefined,
- length: undefined,
- encoding: undefined
- });
- expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
- let readLen = sr.readSync(new ArrayBuffer(4096), { offset: 0 });
- expect(readLen == FILE_CONTENT.length * 2).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_stream_write_async_022 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_2300
- * @tc.name fileIO_test_stream_write_async_023
- * @tc.desc Test the write() interface of class Stream. Callback.
- * Undefined option arguments, use default options.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_stream_write_async_023', 3, async function (done) {
- let fpath = await nextFileName('fileIO_test_stream_write_async_023');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- sr.write(FILE_CONTENT, {
- offset: undefined,
- length: undefined,
- encoding: undefined
- }, (err, bytesWritten1) => {
- if (err) {
- console.log('fileIO_test_stream_write_async_023 err package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
- sr.write(new ArrayBuffer(FILE_CONTENT.length), {
- offset: undefined,
- length: undefined,
- encoding: undefined
- }, (err, bytesWritten2) => {
- if (err) {
- console.log('fileIO_test_stream_write_async_023 err package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
- let readLen = sr.readSync(new ArrayBuffer(4096), { offset: 0 });
- expect(readLen == FILE_CONTENT.length * 2).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- });
- });
- } catch (e) {
- console.log('fileIO_test_stream_write_async_023 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-})
-}
+/*
+ * Copyright (C) 2023 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import {
+ fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect,
+} from '../Common';
+
+export default function fileIOStreamWrite() {
+describe('fileIO_fs_stream_write', function () {
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_0000
+ * @tc.name fileIO_test_stream_write_sync_000
+ * @tc.desc Test the writeSync() interface of class Stream.
+ * Create a file stream in r+ mode, writing an ArrayBuffer.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_sync_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_write_sync_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let bytesWritten1 = sr.writeSync(FILE_CONTENT);
+ expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
+ let bytesWritten2 = sr.writeSync(new ArrayBuffer(FILE_CONTENT.length));
+ expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
+ let readLen = sr.readSync(new ArrayBuffer(4096), { offset: 0 });
+ expect(readLen == FILE_CONTENT.length * 2).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_stream_write_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_0100
+ * @tc.name fileIO_test_stream_write_sync_001
+ * @tc.desc Test the writeSync() interface of class Stream.
+ * Create a file stream in r+ mode, writing a string.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_sync_001', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_write_sync_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let bytesWritten = sr.writeSync(FILE_CONTENT);
+ expect(bytesWritten == FILE_CONTENT.length).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_stream_write_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_0200
+ * @tc.name fileIO_test_stream_write_sync_002
+ * @tc.desc Test the writeSync() interface of class Stream.
+ * Create a file stream in r+ mode, writing a string with offset = 1.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_sync_002', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_write_sync_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let bytesWritten = sr.writeSync(FILE_CONTENT, { offset: 1 });
+ expect(bytesWritten == FILE_CONTENT.length).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_stream_write_sync_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_0300
+ * @tc.name fileIO_test_stream_write_sync_003
+ * @tc.desc Test the writeSync() interface of class Stream.
+ * Write a string with invalide offset = -1.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_sync_003', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_write_sync_003');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ const invalidOffset = -1;
+
+ try {
+ expect(sr !== null).assertTrue();
+ sr.writeSync(new ArrayBuffer(4096), { offset: invalidOffset });
+ expect(false).assertTrue();
+ } catch (e) {
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_stream_write_sync_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_0400
+ * @tc.name fileIO_test_stream_write_sync_004
+ * @tc.desc Test the writeSync() interface of class Stream.
+ * Create a file stream in r+ mode, writing a string with encoding = 'utf-8'.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_sync_004', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_write_sync_004');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let bytesWritten = sr.writeSync(FILE_CONTENT, { encoding: 'utf-8' });
+ expect(bytesWritten == FILE_CONTENT.length).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_stream_write_sync_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_0500
+ * @tc.name fileIO_test_stream_write_sync_005
+ * @tc.desc Test the writeSync() interface of class Stream.
+ * Create a file stream in r+ mode, writing a string with length = 5.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_sync_005', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_write_sync_005');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let bytesWritten = sr.writeSync(FILE_CONTENT, { length: 5 });
+ expect(bytesWritten == 5).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_stream_write_sync_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_0600
+ * @tc.name fileIO_test_stream_write_sync_006
+ * @tc.desc Test the writeSync() interface of class Stream.
+ * Write an ArrayBuffer with invalid length > size of ArrayBuffer(4096).
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_sync_006', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_write_sync_006');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+
+ try {
+ expect(sr !== null).assertTrue();
+ const invalidLength = 4097;
+ sr.writeSync(new ArrayBuffer(4096), { length: invalidLength });
+ expect(false).assertTrue();
+ } catch (e) {
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_stream_write_sync_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_0700
+ * @tc.name fileIO_test_stream_write_sync_007
+ * @tc.desc Test the writeSync() interface of class Stream.
+ * Write a string with invalid length = 9999.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_sync_007', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_write_sync_007');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ const invalidLength = 9999;
+
+ try {
+ expect(sr !== null).assertTrue();
+ sr.writeSync(FILE_CONTENT, { length: invalidLength });
+ expect(false).assertTrue();
+ } catch (e) {
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_stream_write_sync_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_0800
+ * @tc.name fileIO_test_stream_write_sync_008
+ * @tc.desc Test the writeSync() interface of class Stream.
+ * Create a file stream in r+ mode, writing an ArrayBuffer with offset = 1, length = 4096 and encoding = 'utf-8'.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_sync_008', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_write_sync_008');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let bytesWritten = sr.writeSync(new ArrayBuffer(4096), {
+ offset: 1,
+ length: 4096,
+ encoding: 'utf-8'
+ });
+ expect(bytesWritten == 4096).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_stream_write_sync_008 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_0900
+ * @tc.name fileIO_test_stream_write_sync_009
+ * @tc.desc Test the writeSync() interface of class Stream.
+ * Create a file stream in r+ mode, writing a string with offset = 1, length = 11 and encoding = 'utf-8'.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_sync_009', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_write_sync_009');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let bytesWritten = sr.writeSync(FILE_CONTENT, {
+ offset: 1,
+ length: FILE_CONTENT.length,
+ encoding: 'utf-8'
+ });
+ expect(bytesWritten == FILE_CONTENT.length).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_stream_write_sync_009 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_1000
+ * @tc.name fileIO_test_stream_write_sync_010
+ * @tc.desc Test the writeSync() interface of class Stream.
+ * Create a file stream in r+ mode, writing a string with empty option.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_sync_010', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_write_sync_010');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let bytesWritten = sr.writeSync(FILE_CONTENT, {});
+ expect(bytesWritten == FILE_CONTENT.length).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_stream_write_sync_010 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_1100
+ * @tc.name fileIO_test_stream_write_sync_011
+ * @tc.desc Test the writeSync() interface of class Stream.
+ * There are no parameters.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_sync_011', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_write_sync_011');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+
+ try {
+ expect(sr !== null).assertTrue();
+ sr.writeSync();
+ expect(false).assertTrue();
+ } catch (e) {
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_stream_write_sync_011 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_1200
+ * @tc.name fileIO_test_stream_write_sync_012
+ * @tc.desc Test the writeSync() interface of class Stream.
+ * Undefined option arguments, use default options.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_sync_012', 3, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_write_sync_012');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let bytesWritten = sr.writeSync(new ArrayBuffer(4096), undefined);
+ expect(bytesWritten == 4096).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_stream_write_sync_012 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_SYNC_1300
+ * @tc.name fileIO_test_stream_write_sync_013
+ * @tc.desc Test the writeSync() interface of class Stream.
+ * Undefined option arguments, use default options.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_sync_013', 3, async function () {
+ let fpath = await nextFileName('fileIO_test_stream_write_sync_013');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let bytesWritten = sr.writeSync(new ArrayBuffer(4096), {
+ offset: undefined,
+ length: undefined,
+ encoding: undefined
+ });
+ expect(bytesWritten == 4096).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_stream_write_sync_013 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_0000
+ * @tc.name fileIO_test_stream_write_async_000
+ * @tc.desc Test the write() interface of class Stream. Promise.
+ * Create a file stream in r+ mode, writing an ArrayBuffer.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 1
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_async_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_write_async_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let bytesWritten1 = await sr.write(FILE_CONTENT);
+ expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
+ let bytesWritten2 = await sr.write(new ArrayBuffer(FILE_CONTENT.length));
+ expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
+ let readLen = sr.readSync(new ArrayBuffer(4096), { offset: 0 });
+ expect(readLen == FILE_CONTENT.length * 2).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_stream_write_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_0100
+ * @tc.name fileIO_test_stream_write_async_001
+ * @tc.desc Test the write() interface of class Stream. Callback.
+ * Create a file stream in r+ mode, writing an ArrayBuffer.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 1
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_async_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_write_async_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ sr.write(FILE_CONTENT, (err, bytesWritten1) => {
+ if (err) {
+ console.log('fileIO_test_stream_write_async_001 err package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
+ sr.write(new ArrayBuffer(FILE_CONTENT.length), (err, bytesWritten2) => {
+ if (err) {
+ console.log('fileIO_test_stream_write_async_001 err package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
+ let readLen = sr.readSync(new ArrayBuffer(4096), { offset: 0 });
+ expect(readLen == FILE_CONTENT.length * 2).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ });
+ } catch (e) {
+ console.log('fileIO_test_stream_write_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_0200
+ * @tc.name fileIO_test_stream_write_async_002
+ * @tc.desc Test the write() interface of class Stream. Promise.
+ * Create a file stream in r+ mode, writing a string.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_async_002', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_write_async_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let bytesWritten = await sr.write(FILE_CONTENT);
+ expect(bytesWritten == FILE_CONTENT.length).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_stream_write_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_0300
+ * @tc.name fileIO_test_stream_write_async_003
+ * @tc.desc Test the write() interface of class Stream. Callback.
+ * Create a file stream in r+ mode, writing a string.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_async_003', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_write_async_003');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ sr.write(FILE_CONTENT, (err, bytesWritten) => {
+ if (err) {
+ console.log('fileIO_test_stream_write_async_003 err package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(bytesWritten == FILE_CONTENT.length).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_stream_write_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_0400
+ * @tc.name fileIO_test_stream_write_async_004
+ * @tc.desc Test the write() interface of class Stream. Promise.
+ * Create a file stream in r+ mode, writing a string with offset = 1.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_async_004', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_write_async_004');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let bytesWritten = await sr.write(FILE_CONTENT, { offset: 1 });
+ expect(bytesWritten == FILE_CONTENT.length).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_stream_write_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_0500
+ * @tc.name fileIO_test_stream_write_async_005
+ * @tc.desc Test the write() interface of class Stream. Callback.
+ * Create a file stream in r+ mode, writing a string with offset = 1.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_async_005', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_write_async_005');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ sr.write(FILE_CONTENT, {
+ offset: 1
+ }, (err, bytesWritten) => {
+ if (err) {
+ console.log('fileIO_test_stream_write_async_005 err package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(bytesWritten == FILE_CONTENT.length).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_stream_write_async_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_0600
+ * @tc.name fileIO_test_stream_write_async_006
+ * @tc.desc Test the write() interface of class Stream. Callback.
+ * Write a string with invalide offset = -1.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_async_006', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_write_async_006');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ const invalidOffset = -1;
+
+ try {
+ expect(sr !== null).assertTrue();
+ sr.write(new ArrayBuffer(4096), {
+ offset: invalidOffset
+ }, (err) => {
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_stream_write_async_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_0700
+ * @tc.name fileIO_test_stream_write_async_007
+ * @tc.desc Test the write() interface of class Stream. Promise.
+ * Create a file stream in r+ mode, writing a string with encoding = 'utf-8'.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_async_007', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_write_async_007');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let bytesWritten = await sr.write(FILE_CONTENT, { encoding: 'utf-8' });
+ expect(bytesWritten == FILE_CONTENT.length).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_stream_write_async_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_0800
+ * @tc.name fileIO_test_stream_write_async_008
+ * @tc.desc Test the write() interface of class Stream. Promise.
+ * Create a file stream in r+ mode, writing a string with encoding = 'utf-8'.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_async_008', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_write_async_008');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ sr.write(FILE_CONTENT, {
+ encoding: 'utf-8'
+ }, (err, bytesWritten) => {
+ if (err) {
+ console.log('fileIO_test_stream_write_async_008 err package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(bytesWritten == FILE_CONTENT.length).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_stream_write_async_008 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_0900
+ * @tc.name fileIO_test_stream_write_async_009
+ * @tc.desc Test the write() interface of class Stream. Promise.
+ * Create a file stream in r+ mode, writing a string with length = 5.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_async_009', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_write_async_009');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let bytesWritten = await sr.write(FILE_CONTENT, { length: 5 });
+ expect(bytesWritten == 5).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_stream_write_async_009 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_1000
+ * @tc.name fileIO_test_stream_write_async_010
+ * @tc.desc Test the write() interface of class Stream. Callback.
+ * Create a file stream in r+ mode, writing a string with length = 5.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_async_010', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_write_async_010');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ sr.write(FILE_CONTENT, {
+ length: 5
+ }, (err, bytesWritten) => {
+ if (err) {
+ console.log('fileIO_test_stream_write_async_010 err package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(bytesWritten == 5).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_stream_write_async_010 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_1100
+ * @tc.name fileIO_test_stream_write_async_011
+ * @tc.desc Test the write() interface of class Stream. Callback.
+ * Write an ArrayBuffer with invalid length > size of ArrayBuffer(4096).
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_async_011', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_write_async_011');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ const invalidLength = 4097;
+
+ try {
+ expect(sr !== null).assertTrue();
+ sr.write(new ArrayBuffer(4096), {
+ length: invalidLength
+ }, (err) => {
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_stream_write_async_011 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_1200
+ * @tc.name fileIO_test_stream_write_async_012
+ * @tc.desc Test the write() interface of class Stream. Callback.
+ * Write a string with invalid length = 9999.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_async_012', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_write_async_012');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ const invalidLength = 9999;
+
+ try {
+ expect(sr !== null).assertTrue();
+ sr.write(FILE_CONTENT, {
+ length: invalidLength
+ }, (err) => {
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_stream_write_async_012 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_1300
+ * @tc.name fileIO_test_stream_write_async_013
+ * @tc.desc Test the write() interface of class Stream. Promise.
+ * Create a file stream in r+ mode, writing an ArrayBuffer with offset = 1, length = 4096 and encoding = 'utf-8'.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_async_013', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_write_async_013');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let bytesWritten = await sr.write(new ArrayBuffer(4096), {
+ offset: 1,
+ length: 4096,
+ encoding: 'utf-8'
+ });
+ expect(bytesWritten == 4096).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_stream_write_async_013 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_1400
+ * @tc.name fileIO_test_stream_write_async_014
+ * @tc.desc Test the write() interface of class Stream. Callback.
+ * Create a file stream in r+ mode, writing an ArrayBuffer with offset = 1, length = 4096 and encoding = 'utf-8'.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_async_014', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_write_async_014');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ sr.write(new ArrayBuffer(4096), {
+ offset: 1,
+ length: 4096,
+ encoding: 'utf-8'
+ }, (err, bytesWritten) => {
+ if (err) {
+ console.log('fileIO_test_stream_write_async_014 err package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(bytesWritten == 4096).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_stream_write_async_014 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_1500
+ * @tc.name fileIO_test_stream_write_async_015
+ * @tc.desc Test the write() interface of class Stream. Promise.
+ * Create a file stream in r+ mode, writing a string with offset = 1, length = 4096 and encoding = 'utf-8'.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_async_015', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_write_async_015');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let bytesWritten = await sr.write(FILE_CONTENT, {
+ offset: 1,
+ length: FILE_CONTENT.length,
+ encoding: 'utf-8'
+ });
+ expect(bytesWritten == FILE_CONTENT.length).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_stream_write_async_015 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_1600
+ * @tc.name fileIO_test_stream_write_async_016
+ * @tc.desc Test the write() interface of class Stream. Callback.
+ * Create a file stream in r+ mode, writing a string with offset = 1, length = 4096 and encoding = 'utf-8'.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_async_016', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_write_async_016');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ sr.write(FILE_CONTENT, {
+ offset: 1,
+ length: FILE_CONTENT.length,
+ encoding: 'utf-8'
+ }, (err, bytesWritten) => {
+ if (err) {
+ console.log('fileIO_test_stream_write_async_016 err package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(bytesWritten == FILE_CONTENT.length).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_stream_write_async_016 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_1700
+ * @tc.name fileIO_test_stream_write_async_017
+ * @tc.desc Test the write() interface of class Stream. Promise.
+ * Create a file stream in r+ mode, writing a string with empty option.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_async_017', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_write_async_017');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let bytesWritten = await sr.write(FILE_CONTENT, {});
+ expect(bytesWritten == FILE_CONTENT.length).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_stream_write_async_017 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_1800
+ * @tc.name fileIO_test_stream_write_async_018
+ * @tc.desc Test the write() interface of class Stream. Callback.
+ * Create a file stream in r+ mode, writing a string with empty option.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_async_018', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_write_async_018');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ sr.write(FILE_CONTENT, {
+ }, (err, bytesWritten) => {
+ if (err) {
+ console.log('fileIO_test_stream_write_async_018 err package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(bytesWritten == FILE_CONTENT.length).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_stream_write_async_018 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_1900
+ * @tc.name fileIO_test_stream_write_async_019
+ * @tc.desc Test the write() interface of class Stream. Promise.
+ * There are no parameters.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_async_019', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_write_async_019');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+
+ try {
+ expect(sr !== null).assertTrue();
+ await sr.write();
+ expect(false).assertTrue();
+ } catch (e) {
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_stream_write_async_019 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_2000
+ * @tc.name fileIO_test_stream_write_async_020
+ * @tc.desc Test the write() interface of class Stream. Promise.
+ * Undefined option arguments, use default options.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_async_020', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_write_async_020');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let bytesWritten1 = await sr.write(FILE_CONTENT, undefined);
+ expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
+ let bytesWritten2 = await sr.write(new ArrayBuffer(FILE_CONTENT.length), undefined);
+ expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
+ let readLen = sr.readSync(new ArrayBuffer(4096), { offset: 0 });
+ expect(readLen == FILE_CONTENT.length * 2).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_stream_write_async_020 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_2100
+ * @tc.name fileIO_test_stream_write_async_021
+ * @tc.desc Test the write() interface of class Stream. Callback.
+ * Undefined option arguments, use default options.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_async_021', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_write_async_021');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ sr.write(FILE_CONTENT, undefined, (err, bytesWritten1) => {
+ if (err) {
+ console.log('fileIO_test_stream_write_async_021 err package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
+ sr.write(new ArrayBuffer(FILE_CONTENT.length), undefined, (err, bytesWritten2) => {
+ if (err) {
+ console.log('fileIO_test_stream_write_async_021 err package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
+ let readLen = sr.readSync(new ArrayBuffer(4096), { offset: 0 });
+ expect(readLen == FILE_CONTENT.length * 2).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ });
+ } catch (e) {
+ console.log('fileIO_test_stream_write_async_021 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_2200
+ * @tc.name fileIO_test_stream_write_async_022
+ * @tc.desc Test the write() interface of class Stream. Promise.
+ * Undefined option arguments, use default options.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_async_022', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_write_async_022');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ let bytesWritten1 = await sr.write(FILE_CONTENT, {
+ offset: undefined,
+ length: undefined,
+ encoding: undefined
+ });
+ expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
+ let bytesWritten2 = await sr.write(new ArrayBuffer(FILE_CONTENT.length), {
+ offset: undefined,
+ length: undefined,
+ encoding: undefined
+ });
+ expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
+ let readLen = sr.readSync(new ArrayBuffer(4096), { offset: 0 });
+ expect(readLen == FILE_CONTENT.length * 2).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_stream_write_async_022 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_WRITE_ASYNC_2300
+ * @tc.name fileIO_test_stream_write_async_023
+ * @tc.desc Test the write() interface of class Stream. Callback.
+ * Undefined option arguments, use default options.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_stream_write_async_023', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_test_stream_write_async_023');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ sr.write(FILE_CONTENT, {
+ offset: undefined,
+ length: undefined,
+ encoding: undefined
+ }, (err, bytesWritten1) => {
+ if (err) {
+ console.log('fileIO_test_stream_write_async_023 err package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
+ sr.write(new ArrayBuffer(FILE_CONTENT.length), {
+ offset: undefined,
+ length: undefined,
+ encoding: undefined
+ }, (err, bytesWritten2) => {
+ if (err) {
+ console.log('fileIO_test_stream_write_async_023 err package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
+ let readLen = sr.readSync(new ArrayBuffer(4096), { offset: 0 });
+ expect(readLen == FILE_CONTENT.length * 2).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ });
+ } catch (e) {
+ console.log('fileIO_test_stream_write_async_023 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+})
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/access.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/access.test.js
similarity index 96%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/access.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/access.test.js
index 4985c37285192692a90f6eb23c5c5fd509557af6..5c79db65e94e28a9c62eabb3b226f64fa5ecb7c3 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/access.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/members/access.test.js
@@ -1,255 +1,255 @@
-/*
- * Copyright (C) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the 'License');
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an 'AS IS' BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import {
- fileIO, FILE_CONTENT, prepareFile, nextFileName, isIntNum, describe, it, expect,
-} from '../Common';
-
-export default function fileIOAccess() {
-describe('fileIO_fs_access', function () {
-
- /**
- * @tc.number SUB_DF_FILEIO_ACCESS_SYNC_0000
- * @tc.name fileIO_test_access_sync_000
- * @tc.desc Test accessSync() interface.
- * This interface shall work properly in normal case.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_access_sync_000', 0, async function () {
- let fpath = await nextFileName('fileIO_test_access_sync_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- expect(fileIO.accessSync(fpath)).assertTrue();
- let file = fileIO.openSync(fpath);
- expect(isIntNum(file.fd)).assertTrue();
- let readlen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
- expect(readlen == FILE_CONTENT.length).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_access_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_ACCESS_SYNC_0100
- * @tc.name fileIO_test_access_sync_001
- * @tc.desc Test accessSync() interface.
- * The test file is not exist.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_access_sync_001', 0, async function () {
- let fpath = await nextFileName('fileIO_test_access_sync_001');
-
- try {
- let ret = fileIO.accessSync(fpath);
- expect(ret === false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_access_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_ACCESS_SYNC_0200
- * @tc.name fileIO_test_access_sync_002
- * @tc.desc Test accessSync() interface.
- * The test file path is illegal.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_access_sync_002', 0, async function () {
-
- try {
- expect(fileIO.accessSync(-1)).assertTrue();
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_access_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_ACCESS_ASYNC_0000
- * @tc.name fileIO_test_access_async_000
- * @tc.desc Test access() interface. Promise.
- * Use promise to test that the file is exist. Sync method reads data from file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_access_async_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_access_async_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let ret = await fileIO.access(fpath);
- expect(ret === true).assertTrue();
- let file = fileIO.openSync(fpath);
- expect(isIntNum(file.fd)).assertTrue();
- let readlen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
- expect(readlen == FILE_CONTENT.length).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_access_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_ACCESS_ASYNC_0100
- * @tc.name fileIO_test_access_async_001
- * @tc.desc Test access() interface. Callback.
- * Use callback to test that the file is exist. Sync method reads data from file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_access_async_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_access_async_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.access(fpath, (err, ret) => {
- if (err) {
- console.log('fileIO_test_access_async_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(ret === true).assertTrue();
- let file = fileIO.openSync(fpath);
- expect(isIntNum(file.fd)).assertTrue();
- let readlen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
- expect(readlen == FILE_CONTENT.length).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- });
- done();
- } catch (e) {
- console.log('fileIO_test_access_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_ACCESS_ASYNC_0200
- * @tc.name fileIO_test_access_async_002
- * @tc.desc Test access() interface. Promise.
- * Async test file does not exist.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_access_async_002', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_access_async_002');
-
- try {
- let ret = await fileIO.access(fpath);
- expect(ret === false).assertTrue();
- done();
- } catch (e) {
- console.log('fileIO_test_access_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_ACCESS_ASYNC_0300
- * @tc.name fileIO_test_access_async_003
- * @tc.desc Test access() interface. Callback.
- * Async test file does not exist.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_access_async_003', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_access_async_002');
-
- try {
- fileIO.access(fpath, (err, ret) => {
- if (err) {
- console.log('fileIO_test_access_async_003 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(ret === false).assertTrue();
- done();
- });
- } catch (e) {
- console.log('fileIO_test_access_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_ACCESS_ASYNC_0400
- * @tc.name fileIO_test_access_async_004
- * @tc.desc Test access() interface. Promise.
- * Invalid path parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_access_async_004', 0, async function (done) {
-
- try {
- await fileIO.access(-1);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_access_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_ACCESS_ASYNC_0500
- * @tc.name fileIO_test_access_async_005
- * @tc.desc Test access() interface. Callback.
- * Invalid path parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_access_async_005', 0, async function (done) {
-
- try {
- fileIO.access(-1, (err) => {
- expect(false).assertTrue();
- });
- } catch (e) {
- console.log('fileIO_test_access_async_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-});
-}
+/*
+ * Copyright (C) 2023 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import {
+ fileIO, FILE_CONTENT, prepareFile, nextFileName, isIntNum, describe, it, expect,
+} from '../Common';
+
+export default function fileIOAccess() {
+describe('fileIO_fs_access', function () {
+
+ /**
+ * @tc.number SUB_DF_FILEIO_ACCESS_SYNC_0000
+ * @tc.name fileIO_test_access_sync_000
+ * @tc.desc Test accessSync() interface.
+ * This interface shall work properly in normal case.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_access_sync_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_access_sync_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ expect(fileIO.accessSync(fpath)).assertTrue();
+ let file = fileIO.openSync(fpath);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readlen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
+ expect(readlen == FILE_CONTENT.length).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_access_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_ACCESS_SYNC_0100
+ * @tc.name fileIO_test_access_sync_001
+ * @tc.desc Test accessSync() interface.
+ * The test file is not exist.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_access_sync_001', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_access_sync_001');
+
+ try {
+ let ret = fileIO.accessSync(fpath);
+ expect(ret === false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_access_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_ACCESS_SYNC_0200
+ * @tc.name fileIO_test_access_sync_002
+ * @tc.desc Test accessSync() interface.
+ * The test file path is illegal.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_access_sync_002', 0, async function () {
+
+ try {
+ expect(fileIO.accessSync(-1)).assertTrue();
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_access_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_ACCESS_ASYNC_0000
+ * @tc.name fileIO_test_access_async_000
+ * @tc.desc Test access() interface. Promise.
+ * Use promise to test that the file is exist. Sync method reads data from file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_access_async_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_access_async_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let ret = await fileIO.access(fpath);
+ expect(ret === true).assertTrue();
+ let file = fileIO.openSync(fpath);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readlen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
+ expect(readlen == FILE_CONTENT.length).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_access_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_ACCESS_ASYNC_0100
+ * @tc.name fileIO_test_access_async_001
+ * @tc.desc Test access() interface. Callback.
+ * Use callback to test that the file is exist. Sync method reads data from file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_access_async_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_access_async_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.access(fpath, (err, ret) => {
+ if (err) {
+ console.log('fileIO_test_access_async_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(ret === true).assertTrue();
+ let file = fileIO.openSync(fpath);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readlen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
+ expect(readlen == FILE_CONTENT.length).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ });
+ done();
+ } catch (e) {
+ console.log('fileIO_test_access_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_ACCESS_ASYNC_0200
+ * @tc.name fileIO_test_access_async_002
+ * @tc.desc Test access() interface. Promise.
+ * Async test file does not exist.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_access_async_002', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_access_async_002');
+
+ try {
+ let ret = await fileIO.access(fpath);
+ expect(ret === false).assertTrue();
+ done();
+ } catch (e) {
+ console.log('fileIO_test_access_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_ACCESS_ASYNC_0300
+ * @tc.name fileIO_test_access_async_003
+ * @tc.desc Test access() interface. Callback.
+ * Async test file does not exist.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_access_async_003', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_access_async_002');
+
+ try {
+ fileIO.access(fpath, (err, ret) => {
+ if (err) {
+ console.log('fileIO_test_access_async_003 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(ret === false).assertTrue();
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_access_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_ACCESS_ASYNC_0400
+ * @tc.name fileIO_test_access_async_004
+ * @tc.desc Test access() interface. Promise.
+ * Invalid path parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_access_async_004', 0, async function (done) {
+
+ try {
+ await fileIO.access(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_access_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_ACCESS_ASYNC_0500
+ * @tc.name fileIO_test_access_async_005
+ * @tc.desc Test access() interface. Callback.
+ * Invalid path parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_access_async_005', 0, async function (done) {
+
+ try {
+ fileIO.access(-1, (err) => {
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ console.log('fileIO_test_access_async_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+});
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/close.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/close.test.js
similarity index 96%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/close.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/close.test.js
index 254aab40298cd766977cb77dd094924c56ee1a36..17528f2fa7647d4f6d974f17e8ecf70357f0f0c6 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/close.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/members/close.test.js
@@ -1,402 +1,402 @@
-/*
- * Copyright (C) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the 'License');
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an 'AS IS' BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import {
- fileIO, FILE_CONTENT, nextFileName, prepareFile, describe, it, expect,
-} from '../Common';
-
-export default function fileIOClose() {
-describe('fileIO_fs_close', function () {
-
- /**
- * @tc.number SUB_DF_FILEIO_CLOSE_SYNC_0000
- * @tc.name fileIO_test_close_sync_000
- * @tc.desc Test closeSync() interfaces.
- * Open file and close file by fd.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_close_sync_000', 0, async function () {
- let fpath = await nextFileName('fileIO_test_close_sync_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- fileIO.closeSync(file.fd);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_close_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CLOSE_SYNC_0100
- * @tc.name fileIO_test_close_sync_001
- * @tc.desc Test closeSync() interfaces.
- * Open file and close file by file object.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_close_sync_001', 0, async function () {
- let fpath = await nextFileName('fileIO_test_close_sync_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_close_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CLOSE_SYNC_0200
- * @tc.name fileIO_test_close_sync_002
- * @tc.desc Test closeSync() interfaces.
- * Test fd has been closed.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_close_sync_002', 0, async function () {
- let fpath = await nextFileName('fileIO_test_close_sync_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- let fd = file.fd;
- fileIO.closeSync(file);
- fileIO.closeSync(fd);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_close_sync_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900008 && e.message == 'Bad file descriptor').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CLOSE_SYNC_0300
- * @tc.name fileIO_test_close_sync_003
- * @tc.desc Test closeSync() interfaces.
- * Test file has been closed.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_close_sync_003', 0, async function () {
- let fpath = await nextFileName('fileIO_test_close_sync_003');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- fileIO.closeSync(file);
- fileIO.closeSync(file);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_close_sync_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CLOSE_SYNC_0400
- * @tc.name fileIO_test_close_sync_004
- * @tc.desc Test closeSync() interfaces.
- * No parameters.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_close_sync_004', 0, function () {
-
- try {
- fileIO.closeSync();
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_close_sync_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CLOSE_SYNC_0500
- * @tc.name fileIO_test_close_sync_005
- * @tc.desc Test closeSync() interfaces.
- * Illegal type of parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_close_sync_005', 0, function () {
-
- try {
- fileIO.closeSync(-1);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_close_sync_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CLOSE_ASYNC_0000
- * @tc.name fileIO_test_close_async_000
- * @tc.desc Test close() interfaces. Callback.
- * Open file and close file by fd.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_close_async_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_close_async_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- fileIO.close(file.fd, (err) => {
- if(err) {
- console.log('fileIO_test_close_async_000 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_close_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CLOSE_ASYNC_0100
- * @tc.name fileIO_test_close_async_001
- * @tc.desc Test close() interfaces. Callback.
- * Open file and close file by file object.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_close_async_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_close_async_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- fileIO.close(file, (err) => {
- if (err) {
- console.log('fileIO_test_close_async_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_close_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CLOSE_ASYNC_0200
- * @tc.name fileIO_test_close_async_002
- * @tc.desc Test close() interfaces. Promise.
- * Open file and close file by fd.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_close_async_002', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_close_async_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- await fileIO.close(file.fd);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_close_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CLOSE_ASYNC_0300
- * @tc.name fileIO_test_close_async_003
- * @tc.desc Test close() interfaces. Promise.
- * Open file and close file by file object.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_close_async_003', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_close_async_003');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- await fileIO.close(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_close_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CLOSE_ASYNC_0400
- * @tc.name fileIO_test_close_async_004
- * @tc.desc Test close() interfaces. Promise.
- * Test file has been closed.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_close_async_004', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_close_async_004');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- let fd = file.fd;
- await fileIO.close(file);
- await fileIO.close(fd);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_close_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900008 && e.message == 'Bad file descriptor').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CLOSE_ASYNC_0500
- * @tc.name fileIO_test_close_async_005
- * @tc.desc Test close() interfaces. Promise.
- * Test file has been closed.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_close_async_005', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_close_async_005');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- await fileIO.close(file);
- await fileIO.close(file);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_close_async_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CLOSE_ASYNC_0600
- * @tc.name fileIO_test_close_async_006
- * @tc.desc Test close() interfaces. Promise.
- * There are multiple parameters.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_close_async_006', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_close_async_006');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- await fileIO.close(file.fd, 2);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_close_async_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CLOSE_ASYNC_0700
- * @tc.name fileIO_test_close_async_007
- * @tc.desc Test close() interfaces.
- * Illegal type of parameter. Promise.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_close_async_007', 0, async function (done) {
-
- try {
- await fileIO.close(-1);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_close_async_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CLOSE_ASYNC_0800
- * @tc.name fileIO_test_close_async_008
- * @tc.desc Test close() interfaces. Promise.
- * No parameters.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_close_async_008', 0, async function (done) {
-
- try {
- await fileIO.close();
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_close_async_008 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-});
-}
+/*
+ * Copyright (C) 2023 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import {
+ fileIO, FILE_CONTENT, nextFileName, prepareFile, describe, it, expect,
+} from '../Common';
+
+export default function fileIOClose() {
+describe('fileIO_fs_close', function () {
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CLOSE_SYNC_0000
+ * @tc.name fileIO_test_close_sync_000
+ * @tc.desc Test closeSync() interfaces.
+ * Open file and close file by fd.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_close_sync_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_close_sync_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ fileIO.closeSync(file.fd);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_close_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CLOSE_SYNC_0100
+ * @tc.name fileIO_test_close_sync_001
+ * @tc.desc Test closeSync() interfaces.
+ * Open file and close file by file object.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_close_sync_001', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_close_sync_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_close_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CLOSE_SYNC_0200
+ * @tc.name fileIO_test_close_sync_002
+ * @tc.desc Test closeSync() interfaces.
+ * Test fd has been closed.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_close_sync_002', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_close_sync_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ let fd = file.fd;
+ fileIO.closeSync(file);
+ fileIO.closeSync(fd);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_close_sync_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900008 && e.message == 'Bad file descriptor').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CLOSE_SYNC_0300
+ * @tc.name fileIO_test_close_sync_003
+ * @tc.desc Test closeSync() interfaces.
+ * Test file has been closed.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_close_sync_003', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_close_sync_003');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ fileIO.closeSync(file);
+ fileIO.closeSync(file);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_close_sync_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CLOSE_SYNC_0400
+ * @tc.name fileIO_test_close_sync_004
+ * @tc.desc Test closeSync() interfaces.
+ * No parameters.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_close_sync_004', 0, function () {
+
+ try {
+ fileIO.closeSync();
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_close_sync_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CLOSE_SYNC_0500
+ * @tc.name fileIO_test_close_sync_005
+ * @tc.desc Test closeSync() interfaces.
+ * Illegal type of parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_close_sync_005', 0, function () {
+
+ try {
+ fileIO.closeSync(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_close_sync_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CLOSE_ASYNC_0000
+ * @tc.name fileIO_test_close_async_000
+ * @tc.desc Test close() interfaces. Callback.
+ * Open file and close file by fd.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_close_async_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_close_async_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ fileIO.close(file.fd, (err) => {
+ if(err) {
+ console.log('fileIO_test_close_async_000 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_close_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CLOSE_ASYNC_0100
+ * @tc.name fileIO_test_close_async_001
+ * @tc.desc Test close() interfaces. Callback.
+ * Open file and close file by file object.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_close_async_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_close_async_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ fileIO.close(file, (err) => {
+ if (err) {
+ console.log('fileIO_test_close_async_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_close_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CLOSE_ASYNC_0200
+ * @tc.name fileIO_test_close_async_002
+ * @tc.desc Test close() interfaces. Promise.
+ * Open file and close file by fd.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_close_async_002', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_close_async_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ await fileIO.close(file.fd);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_close_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CLOSE_ASYNC_0300
+ * @tc.name fileIO_test_close_async_003
+ * @tc.desc Test close() interfaces. Promise.
+ * Open file and close file by file object.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_close_async_003', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_close_async_003');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ await fileIO.close(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_close_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CLOSE_ASYNC_0400
+ * @tc.name fileIO_test_close_async_004
+ * @tc.desc Test close() interfaces. Promise.
+ * Test file has been closed.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_close_async_004', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_close_async_004');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ let fd = file.fd;
+ await fileIO.close(file);
+ await fileIO.close(fd);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_close_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900008 && e.message == 'Bad file descriptor').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CLOSE_ASYNC_0500
+ * @tc.name fileIO_test_close_async_005
+ * @tc.desc Test close() interfaces. Promise.
+ * Test file has been closed.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_close_async_005', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_close_async_005');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ await fileIO.close(file);
+ await fileIO.close(file);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_close_async_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CLOSE_ASYNC_0600
+ * @tc.name fileIO_test_close_async_006
+ * @tc.desc Test close() interfaces. Promise.
+ * There are multiple parameters.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_close_async_006', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_close_async_006');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ await fileIO.close(file.fd, 2);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_close_async_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CLOSE_ASYNC_0700
+ * @tc.name fileIO_test_close_async_007
+ * @tc.desc Test close() interfaces.
+ * Illegal type of parameter. Promise.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_close_async_007', 0, async function (done) {
+
+ try {
+ await fileIO.close(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_close_async_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CLOSE_ASYNC_0800
+ * @tc.name fileIO_test_close_async_008
+ * @tc.desc Test close() interfaces. Promise.
+ * No parameters.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_close_async_008', 0, async function (done) {
+
+ try {
+ await fileIO.close();
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_close_async_008 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+});
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/copyDir.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/copyDir.test.js
old mode 100644
new mode 100755
similarity index 100%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/copyDir.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/copyDir.test.js
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/copyFile.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/copyFile.test.js
similarity index 97%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/copyFile.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/copyFile.test.js
index 906cc47ed5c4cce1a463aaf900c58b9e3ae03abe..92209f6fa9882d4068265e883dd512a5231182dc 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/copyFile.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/members/copyFile.test.js
@@ -1,885 +1,885 @@
-/*
- * Copyright (C) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the 'License');
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an 'AS IS' BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import {
- fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect, randomString
-} from '../Common';
-
-export default function fileIOCopyfile() {
-describe('fileIO_fs_copyfile', function () {
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_SYNC_0000
- * @tc.name fileIO_copy_file_sync_000
- * @tc.desc Test copyFileSync() interfaces.
- * Test file copied successfully by path.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_copy_file_sync_000', 0, async function () {
- let fpath = await nextFileName('fileIO_copy_file_sync_000');
- let fpathTarget = fpath + 'tgt';
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.copyFileSync(fpath, fpathTarget);
- let stat1 = fileIO.statSync(fpath);
- let stat2 = fileIO.statSync(fpathTarget);
- expect(stat1.size == stat2.size).assertTrue();
- fileIO.unlinkSync(fpath);
- fileIO.unlinkSync(fpathTarget);
- } catch (e) {
- console.log('fileIO_copy_file_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_SYNC_0100
- * @tc.name fileIO_copy_file_sync_001
- * @tc.desc Test copyFileSync() interfaces.
- * Test file copied successfully by file descriptor.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_sync_001', 0, async function () {
- let fpath = await nextFileName('fileIO_copy_file_sync_001');
- let fpathTarget = fpath + 'tgt';
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- fileIO.copyFileSync(file.fd, fpathTarget);
- let stat1 = fileIO.statSync(fpath);
- let stat2 = fileIO.statSync(fpathTarget);
- expect(stat1.size == stat2.size).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- fileIO.unlinkSync(fpathTarget);
- } catch (e) {
- console.log('fileIO_copy_file_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_SYNC_0200
- * @tc.name fileIO_copy_file_sync_002
- * @tc.desc Test copyFileSync() interfaces.
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_sync_002', 0, async function () {
- let fpath = await nextFileName('fileIO_copy_file_sync_002');
- let fpathTarget = fpath + 'tgt';
-
- try {
- fileIO.copyFileSync(fpath, fpathTarget);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_copy_file_sync_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_SYNC_0300
- * @tc.name fileIO_copy_file_sync_003
- * @tc.desc Test copyFileSync() interfaces.
- * Missing parameters.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_sync_003', 0, function () {
-
- try {
- fileIO.copyFileSync();
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_copy_file_sync_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_SYNC_0400
- * @tc.name fileIO_copy_file_sync_004
- * @tc.desc Test copyFileSync() interfaces.
- * Invalid type of mode.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_sync_004', 0, async function () {
- let fpath = await nextFileName('fileIO_copy_file_sync_004');
- let fpathTarget = fpath + 'tgt';
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.copyFileSync(fpath, fpathTarget, '0');
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_copy_file_sync_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_SYNC_0500
- * @tc.name fileIO_copy_file_sync_005
- * @tc.desc Test copyFileSync() interfaces.
- * Test file copied successfully by file descriptor.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_sync_005', 0, async function () {
- let fpath = await nextFileName('fileIO_copy_file_sync_005');
- let fpathTarget = fpath + 'tgt';
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let fileTgt = fileIO.openSync(fpathTarget, fileIO.OpenMode.CREATE | fileIO.OpenMode.READ_WRITE);
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- fileIO.copyFileSync(file.fd, fileTgt.fd);
- let stat1 = fileIO.statSync(fpath);
- let stat2 = fileIO.statSync(fpathTarget);
- expect(stat1.size == stat2.size).assertTrue();
- fileIO.closeSync(file);
- fileIO.closeSync(fileTgt);
- fileIO.unlinkSync(fpath);
- fileIO.unlinkSync(fpathTarget);
- } catch (e) {
- console.log('fileIO_copy_file_sync_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_SYNC_0600
- * @tc.name fileIO_copy_file_sync_006
- * @tc.desc Test copyFileSync() interfaces.
- * Test file copied successfully by file descriptor and path.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_sync_006', 0, async function () {
- let fpath = await nextFileName('fileIO_copy_file_sync_006');
- let fpathTarget = fpath + 'tgt';
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let fileTgt = fileIO.openSync(fpathTarget, fileIO.OpenMode.CREATE | fileIO.OpenMode.READ_WRITE);
-
- try {
- fileIO.copyFileSync(fpath, fileTgt.fd);
- let stat1 = fileIO.statSync(fpath);
- let stat2 = fileIO.statSync(fpathTarget);
- expect(stat1.size == stat2.size).assertTrue();
- fileIO.closeSync(fileTgt);
- fileIO.unlinkSync(fpath);
- fileIO.unlinkSync(fpathTarget);
- } catch (e) {
- console.log('fileIO_copy_file_sync_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_SYNC_0700
- * @tc.name fileIO_copy_file_sync_007
- * @tc.desc Test copyFileSync() interfaces.
- * Don't support mode = 1.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_sync_007', 0, async function (done) {
- let fpath = await nextFileName('fileIO_copy_file_sync_007');
- let fpathTarget = fpath + 'tgt';
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.copyFileSync(fpath, fpathTarget, 1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_copy_file_sync_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_SYNC_0800
- * @tc.name fileIO_copy_file_sync_008
- * @tc.desc Test copyFileSync() interfaces.
- * The length of file name is too long.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_sync_008', 0, async function () {
- let fpath = await nextFileName('fileIO_copy_file_sync_008');
- let fpathTarget = fpath + randomString(250);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.copyFileSync(fpath, fpathTarget);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_copy_file_sync_008 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900030 && e.message == 'File name too long').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_SYNC_0900
- * @tc.name fileIO_copy_file_sync_009
- * @tc.desc Test copyFileSync() interfaces.
- * Use default mode = 0.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_sync_009', 3, async function () {
- let fpath = await nextFileName('fileIO_copy_file_sync_009');
- let fpathTarget = fpath + 'tgt';
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.copyFileSync(fpath, fpathTarget, undefined);
- let stat1 = fileIO.statSync(fpath);
- let stat2 = fileIO.statSync(fpathTarget);
- expect(stat1.size == stat2.size).assertTrue();
- fileIO.unlinkSync(fpath);
- fileIO.unlinkSync(fpathTarget);
- } catch (e) {
- console.log('fileIO_copy_file_sync_009 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_0000
- * @tc.name fileIO_copy_file_async_000
- * @tc.desc Test copyFile() interfaces. Promise.
- * Test file copied successfully by path.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_async_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_copy_file_async_000');
- let fpathTarget = fpath + 'tgt';
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- await fileIO.copyFile(fpath, fpathTarget);
- let stat1 = fileIO.statSync(fpath);
- let stat2 = fileIO.statSync(fpathTarget);
- expect(stat1.size == stat2.size).assertTrue();
- fileIO.unlinkSync(fpath);
- fileIO.unlinkSync(fpathTarget);
- done();
- } catch (e) {
- console.log('fileIO_copy_file_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_0100
- * @tc.name fileIO_copy_file_async_001
- * @tc.desc Test copyFile() interfaces. Callback.
- * Test file copied successfully by path.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_async_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_copy_file_async_001');
- let fpathTarget = fpath + 'tgt';
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.copyFile(fpath, fpathTarget, (err) => {
- if (err) {
- console.log('fileIO_copy_file_async_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- let stat1 = fileIO.statSync(fpath);
- let stat2 = fileIO.statSync(fpathTarget);
- expect(stat1.size == stat2.size).assertTrue();
- fileIO.unlinkSync(fpath);
- fileIO.unlinkSync(fpathTarget);
- done();
- });
- } catch (e) {
- console.log('fileIO_copy_file_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_0200
- * @tc.name fileIO_copy_file_async_002
- * @tc.desc Test copyFile() interfaces. Promise.
- * Test file copied successfully by file descriptor.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_async_002', 0, async function (done) {
- let fpath = await nextFileName('fileIO_copy_file_async_002');
- let fpathTarget = fpath + 'tgt';
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.CREATE | fileIO.OpenMode.READ_WRITE);
- await fileIO.copyFile(file.fd, fpathTarget);
- let stat1 = fileIO.statSync(fpath);
- let stat2 = fileIO.statSync(fpathTarget);
- expect(stat1.size == stat2.size).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- fileIO.unlinkSync(fpathTarget);
- done();
- } catch (e) {
- console.log('fileIO_copy_file_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_0300
- * @tc.name fileIO_copy_file_async_003
- * @tc.desc Test copyFile() interfaces. Promise.
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_async_003', 0, async function (done) {
- let fpath = await nextFileName('fileIO_copy_file_async_003');
- let fpathTarget = fpath + 'tgt';
-
- try {
- await fileIO.copyFile(fpath, fpathTarget);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_copy_file_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_0400
- * @tc.name fileIO_copy_file_async_004
- * @tc.desc Test copyFile() interfaces. Callback.
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_async_004', 0, async function (done) {
- let fpath = await nextFileName('fileIO_copy_file_async_004');
- let fpathTarget = fpath + 'tgt';
-
- try {
- fileIO.copyFile(fpath, fpathTarget, (err) => {
- if (err) {
- console.log('fileIO_copy_file_async_005 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('fileIO_copy_file_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_0500
- * @tc.name fileIO_copy_file_async_005
- * @tc.desc Test copyFile() interfaces. Promise.then().catch()
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_async_005', 0, async function (done) {
- let fpath = await nextFileName('fileIO_copy_file_async_005');
- let fpathTarget = fpath + 'tgt';
-
- try {
- fileIO.copyFile(fpath, fpathTarget).then(() => {
- expect(false).assertTrue();
- }).catch((err) => {
- console.log('fileIO_copy_file_async_005 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
- done();
- });
- } catch (e) {
- console.log('fileIO_copy_file_async_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_0600
- * @tc.name fileIO_copy_file_async_006
- * @tc.desc Test copyFile() interfaces. Promise.
- * Missing Parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_async_006', 0, async function (done) {
- let fpath = await nextFileName('fileIO_copy_file_async_006');
-
- try {
- await fileIO.copyFile(fpath);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_copy_file_async_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_0700
- * @tc.name fileIO_copy_file_async_007
- * @tc.desc Test copyFile() interfaces. Callback.
- * Missing Parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_async_007', 0, async function (done) {
- let fpath = await nextFileName('fileIO_copy_file_async_007');
-
- try {
- fileIO.copyFile(fpath, (err) => {
- expect(false).assertTrue();
- });
- } catch (e) {
- console.log('fileIO_copy_file_async_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_0800
- * @tc.name fileIO_copy_file_async_008
- * @tc.desc Test copyFile() interfaces. Promise.
- * Test file copied successfully by path when mode = 0.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_async_008', 0, async function (done) {
- let fpath = await nextFileName('fileIO_copy_file_async_008');
- let fpathTarget = fpath + 'tgt';
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- await fileIO.copyFile(fpath, fpathTarget, 0);
- let stat1 = fileIO.statSync(fpath);
- let stat2 = fileIO.statSync(fpathTarget);
- expect(stat1.size == stat2.size).assertTrue();
- fileIO.unlinkSync(fpath);
- fileIO.unlinkSync(fpathTarget);
- done();
- } catch (e) {
- console.log('fileIO_copy_file_async_008 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_0900
- * @tc.name fileIO_copy_file_async_009
- * @tc.desc Test copyFile() interfaces. Callback.
- * Test file copied successfully by path when mode = 0.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_async_009', 0, async function (done) {
- let fpath = await nextFileName('fileIO_copy_file_async_009');
- let fpathTarget = fpath + 'tgt';
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.copyFile(fpath, fpathTarget, 0, (err) => {
- if (err) {
- console.log('fileIO_copy_file_async_007 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- let stat1 = fileIO.statSync(fpath);
- let stat2 = fileIO.statSync(fpathTarget);
- expect(stat1.size == stat2.size).assertTrue();
- fileIO.unlinkSync(fpath);
- fileIO.unlinkSync(fpathTarget);
- done();
- });
- } catch (e) {
- console.log('fileIO_copy_file_async_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_1000
- * @tc.name fileIO_copy_file_async_010
- * @tc.desc Test copyFile() interfaces. Callback.
- * Don't support mode = 1.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_async_010', 0, async function (done) {
- let fpath = await nextFileName('fileIO_copy_file_async_010');
- let fpathTarget = fpath + 'tgt';
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.copyFile(fpath, fpathTarget, 1, (err) => {
- expect(false).assertTrue();
- });
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_copy_file_async_010 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_1100
- * @tc.name fileIO_copy_file_async_011
- * @tc.desc Test copyFile() interfaces. Promise.
- * Invalid type of mode.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_async_011', 0, async function (done) {
- let fpath = await nextFileName('fileIO_copy_file_async_011');
- let fpathTarget = fpath + 'tgt';
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- await fileIO.copyFile(fpath, fpathTarget, '0');
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_copy_file_async_011 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_1200
- * @tc.name fileIO_copy_file_async_012
- * @tc.desc Test copyFile() interfaces. Promise.
- * Test file copied successfully by file descriptor.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_async_012', 0, async function (done) {
- let fpath = await nextFileName('fileIO_copy_file_async_012');
- let fpathTarget = fpath + 'tgt';
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let fileTgt = fileIO.openSync(fpathTarget, fileIO.OpenMode.CREATE | fileIO.OpenMode.READ_WRITE);
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- await fileIO.copyFile(file.fd, fileTgt.fd);
- let stat1 = fileIO.statSync(fpath);
- let stat2 = fileIO.statSync(fpathTarget);
- expect(stat1.size == stat2.size).assertTrue();
- fileIO.closeSync(file);
- fileIO.closeSync(fileTgt);
- fileIO.unlinkSync(fpath);
- fileIO.unlinkSync(fpathTarget);
- done();
- } catch (e) {
- console.log('fileIO_copy_file_async_012 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_1300
- * @tc.name fileIO_copy_file_async_013
- * @tc.desc Test copyFile() interfaces. Callback.
- * Test file copied successfully by file descriptor.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_async_013', 0, async function (done) {
- let fpath = await nextFileName('fileIO_copy_file_async_012');
- let fpathTarget = fpath + 'tgt';
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let fileTgt = fileIO.openSync(fpathTarget, fileIO.OpenMode.CREATE | fileIO.OpenMode.READ_WRITE);
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- fileIO.copyFile(file.fd, fileTgt.fd, (err) => {
- if (err) {
- console.log('fileIO_copy_file_async_013 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- let stat1 = fileIO.statSync(fpath);
- let stat2 = fileIO.statSync(fpathTarget);
- expect(stat1.size == stat2.size).assertTrue();
- fileIO.closeSync(file);
- fileIO.closeSync(fileTgt);
- fileIO.unlinkSync(fpath);
- fileIO.unlinkSync(fpathTarget);
- done();
- });
- } catch (e) {
- console.log('fileIO_copy_file_async_013 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_1400
- * @tc.name fileIO_copy_file_async_014
- * @tc.desc Test copyFile() interfaces. Promise.
- * Test file copied successfully by file descriptor and path when mode = 0.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_async_014', 0, async function (done) {
- let fpath = await nextFileName('fileIO_copy_file_async_014');
- let fpathTarget = fpath + 'tgt';
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- expect(prepareFile(fpathTarget, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpathTarget, fileIO.OpenMode.READ_WRITE);
- await fileIO.copyFile(fpath, file.fd, 0);
- let stat1 = fileIO.statSync(fpath);
- let stat2 = fileIO.statSync(fpathTarget);
- expect(stat1.size == stat2.size).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- fileIO.unlinkSync(fpathTarget);
- done();
- } catch (e) {
- console.log('fileIO_copy_file_async_014 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_1500
- * @tc.name fileIO_copy_file_async_015
- * @tc.desc Test copyFile() interfaces. Callback.
- * Test file copied successfully by file descriptor and path.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_async_015', 0, async function (done) {
- let fpath = await nextFileName('fileIO_copy_file_async_014');
- let fpathTarget = fpath + 'tgt';
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpathTarget, fileIO.OpenMode.CREATE | fileIO.OpenMode.READ_WRITE);
-
- try {
- fileIO.copyFile(fpath, file.fd, 0, (err) => {
- if (err) {
- console.log('fileIO_copy_file_async_013 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- let stat1 = fileIO.statSync(fpath);
- let stat2 = fileIO.statSync(fpathTarget);
- expect(stat1.size == stat2.size).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- fileIO.unlinkSync(fpathTarget);
- done();
- });
- } catch (e) {
- console.log('fileIO_copy_file_async_015 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_1600
- * @tc.name fileIO_copy_file_async_016
- * @tc.desc Test copyFile() interfaces. Promise
- * The length of file name is too long.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_async_016', 0, async function (done) {
- let fpath = await nextFileName('fileIO_copy_file_async_016');
- let fpathTarget = fpath + randomString(250);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- await fileIO.copyFile(fpath, fpathTarget);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_copy_file_async_016 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900030 && e.message == 'File name too long').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_1700
- * @tc.name fileIO_copy_file_async_017
- * @tc.desc Test copyFile() interfaces. Callback
- * The length of file name is too long.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_async_017', 0, async function (done) {
- let fpath = await nextFileName('fileIO_copy_file_async_017');
- let fpathTarget = fpath + randomString(250);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.copyFile(fpath, fpathTarget, (err) => {
- if (err) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_copy_file_async_017 error: {message: ' + err.message + ', code: ' + err.code);
- expect(err.code == 13900030 && err.message == 'File name too long').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('fileIO_copy_file_async_017 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_1800
- * @tc.name fileIO_copy_file_async_018
- * @tc.desc Test copyFile() interfaces. Promise
- * Use default mode = 0.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_async_018', 3, async function (done) {
- let fpath = await nextFileName('fileIO_copy_file_async_018');
- let fpathTarget = fpath + 'tgt';
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- await fileIO.copyFile(fpath, fpathTarget, undefined);
- let stat1 = fileIO.statSync(fpath);
- let stat2 = fileIO.statSync(fpathTarget);
- expect(stat1.size == stat2.size).assertTrue();
- fileIO.unlinkSync(fpath);
- fileIO.unlinkSync(fpathTarget);
- done();
- } catch (e) {
- console.log('fileIO_copy_file_async_018 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_1900
- * @tc.name fileIO_copy_file_async_019
- * @tc.desc Test copyFile() interfaces. Callback
- * Use default mode = 0.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_copy_file_async_019', 3, async function (done) {
- let fpath = await nextFileName('fileIO_copy_file_async_019');
- let fpathTarget = fpath + 'tgt';
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.copyFile(fpath, fpathTarget, undefined, (err) => {
- if (err) {
- console.log('fileIO_copy_file_async_019 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- let stat1 = fileIO.statSync(fpath);
- let stat2 = fileIO.statSync(fpathTarget);
- expect(stat1.size == stat2.size).assertTrue();
- fileIO.unlinkSync(fpath);
- fileIO.unlinkSync(fpathTarget);
- done();
- });
- } catch (e) {
- console.log('fileIO_copy_file_async_019 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-});
-}
+/*
+ * Copyright (C) 2023 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import {
+ fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect, randomString
+} from '../Common';
+
+export default function fileIOCopyfile() {
+describe('fileIO_fs_copyfile', function () {
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_SYNC_0000
+ * @tc.name fileIO_copy_file_sync_000
+ * @tc.desc Test copyFileSync() interfaces.
+ * Test file copied successfully by path.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_copy_file_sync_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_copy_file_sync_000');
+ let fpathTarget = fpath + 'tgt';
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.copyFileSync(fpath, fpathTarget);
+ let stat1 = fileIO.statSync(fpath);
+ let stat2 = fileIO.statSync(fpathTarget);
+ expect(stat1.size == stat2.size).assertTrue();
+ fileIO.unlinkSync(fpath);
+ fileIO.unlinkSync(fpathTarget);
+ } catch (e) {
+ console.log('fileIO_copy_file_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_SYNC_0100
+ * @tc.name fileIO_copy_file_sync_001
+ * @tc.desc Test copyFileSync() interfaces.
+ * Test file copied successfully by file descriptor.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_sync_001', 0, async function () {
+ let fpath = await nextFileName('fileIO_copy_file_sync_001');
+ let fpathTarget = fpath + 'tgt';
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ fileIO.copyFileSync(file.fd, fpathTarget);
+ let stat1 = fileIO.statSync(fpath);
+ let stat2 = fileIO.statSync(fpathTarget);
+ expect(stat1.size == stat2.size).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ fileIO.unlinkSync(fpathTarget);
+ } catch (e) {
+ console.log('fileIO_copy_file_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_SYNC_0200
+ * @tc.name fileIO_copy_file_sync_002
+ * @tc.desc Test copyFileSync() interfaces.
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_sync_002', 0, async function () {
+ let fpath = await nextFileName('fileIO_copy_file_sync_002');
+ let fpathTarget = fpath + 'tgt';
+
+ try {
+ fileIO.copyFileSync(fpath, fpathTarget);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_copy_file_sync_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_SYNC_0300
+ * @tc.name fileIO_copy_file_sync_003
+ * @tc.desc Test copyFileSync() interfaces.
+ * Missing parameters.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_sync_003', 0, function () {
+
+ try {
+ fileIO.copyFileSync();
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_copy_file_sync_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_SYNC_0400
+ * @tc.name fileIO_copy_file_sync_004
+ * @tc.desc Test copyFileSync() interfaces.
+ * Invalid type of mode.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_sync_004', 0, async function () {
+ let fpath = await nextFileName('fileIO_copy_file_sync_004');
+ let fpathTarget = fpath + 'tgt';
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.copyFileSync(fpath, fpathTarget, '0');
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_copy_file_sync_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_SYNC_0500
+ * @tc.name fileIO_copy_file_sync_005
+ * @tc.desc Test copyFileSync() interfaces.
+ * Test file copied successfully by file descriptor.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_sync_005', 0, async function () {
+ let fpath = await nextFileName('fileIO_copy_file_sync_005');
+ let fpathTarget = fpath + 'tgt';
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let fileTgt = fileIO.openSync(fpathTarget, fileIO.OpenMode.CREATE | fileIO.OpenMode.READ_WRITE);
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ fileIO.copyFileSync(file.fd, fileTgt.fd);
+ let stat1 = fileIO.statSync(fpath);
+ let stat2 = fileIO.statSync(fpathTarget);
+ expect(stat1.size == stat2.size).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.closeSync(fileTgt);
+ fileIO.unlinkSync(fpath);
+ fileIO.unlinkSync(fpathTarget);
+ } catch (e) {
+ console.log('fileIO_copy_file_sync_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_SYNC_0600
+ * @tc.name fileIO_copy_file_sync_006
+ * @tc.desc Test copyFileSync() interfaces.
+ * Test file copied successfully by file descriptor and path.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_sync_006', 0, async function () {
+ let fpath = await nextFileName('fileIO_copy_file_sync_006');
+ let fpathTarget = fpath + 'tgt';
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let fileTgt = fileIO.openSync(fpathTarget, fileIO.OpenMode.CREATE | fileIO.OpenMode.READ_WRITE);
+
+ try {
+ fileIO.copyFileSync(fpath, fileTgt.fd);
+ let stat1 = fileIO.statSync(fpath);
+ let stat2 = fileIO.statSync(fpathTarget);
+ expect(stat1.size == stat2.size).assertTrue();
+ fileIO.closeSync(fileTgt);
+ fileIO.unlinkSync(fpath);
+ fileIO.unlinkSync(fpathTarget);
+ } catch (e) {
+ console.log('fileIO_copy_file_sync_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_SYNC_0700
+ * @tc.name fileIO_copy_file_sync_007
+ * @tc.desc Test copyFileSync() interfaces.
+ * Don't support mode = 1.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_sync_007', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_copy_file_sync_007');
+ let fpathTarget = fpath + 'tgt';
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.copyFileSync(fpath, fpathTarget, 1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_copy_file_sync_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_SYNC_0800
+ * @tc.name fileIO_copy_file_sync_008
+ * @tc.desc Test copyFileSync() interfaces.
+ * The length of file name is too long.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_sync_008', 0, async function () {
+ let fpath = await nextFileName('fileIO_copy_file_sync_008');
+ let fpathTarget = fpath + randomString(250);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.copyFileSync(fpath, fpathTarget);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_copy_file_sync_008 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900030 && e.message == 'File name too long').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_SYNC_0900
+ * @tc.name fileIO_copy_file_sync_009
+ * @tc.desc Test copyFileSync() interfaces.
+ * Use default mode = 0.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_sync_009', 3, async function () {
+ let fpath = await nextFileName('fileIO_copy_file_sync_009');
+ let fpathTarget = fpath + 'tgt';
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.copyFileSync(fpath, fpathTarget, undefined);
+ let stat1 = fileIO.statSync(fpath);
+ let stat2 = fileIO.statSync(fpathTarget);
+ expect(stat1.size == stat2.size).assertTrue();
+ fileIO.unlinkSync(fpath);
+ fileIO.unlinkSync(fpathTarget);
+ } catch (e) {
+ console.log('fileIO_copy_file_sync_009 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_0000
+ * @tc.name fileIO_copy_file_async_000
+ * @tc.desc Test copyFile() interfaces. Promise.
+ * Test file copied successfully by path.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_async_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_copy_file_async_000');
+ let fpathTarget = fpath + 'tgt';
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ await fileIO.copyFile(fpath, fpathTarget);
+ let stat1 = fileIO.statSync(fpath);
+ let stat2 = fileIO.statSync(fpathTarget);
+ expect(stat1.size == stat2.size).assertTrue();
+ fileIO.unlinkSync(fpath);
+ fileIO.unlinkSync(fpathTarget);
+ done();
+ } catch (e) {
+ console.log('fileIO_copy_file_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_0100
+ * @tc.name fileIO_copy_file_async_001
+ * @tc.desc Test copyFile() interfaces. Callback.
+ * Test file copied successfully by path.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_async_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_copy_file_async_001');
+ let fpathTarget = fpath + 'tgt';
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.copyFile(fpath, fpathTarget, (err) => {
+ if (err) {
+ console.log('fileIO_copy_file_async_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ let stat1 = fileIO.statSync(fpath);
+ let stat2 = fileIO.statSync(fpathTarget);
+ expect(stat1.size == stat2.size).assertTrue();
+ fileIO.unlinkSync(fpath);
+ fileIO.unlinkSync(fpathTarget);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_copy_file_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_0200
+ * @tc.name fileIO_copy_file_async_002
+ * @tc.desc Test copyFile() interfaces. Promise.
+ * Test file copied successfully by file descriptor.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_async_002', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_copy_file_async_002');
+ let fpathTarget = fpath + 'tgt';
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.CREATE | fileIO.OpenMode.READ_WRITE);
+ await fileIO.copyFile(file.fd, fpathTarget);
+ let stat1 = fileIO.statSync(fpath);
+ let stat2 = fileIO.statSync(fpathTarget);
+ expect(stat1.size == stat2.size).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ fileIO.unlinkSync(fpathTarget);
+ done();
+ } catch (e) {
+ console.log('fileIO_copy_file_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_0300
+ * @tc.name fileIO_copy_file_async_003
+ * @tc.desc Test copyFile() interfaces. Promise.
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_async_003', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_copy_file_async_003');
+ let fpathTarget = fpath + 'tgt';
+
+ try {
+ await fileIO.copyFile(fpath, fpathTarget);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_copy_file_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_0400
+ * @tc.name fileIO_copy_file_async_004
+ * @tc.desc Test copyFile() interfaces. Callback.
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_async_004', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_copy_file_async_004');
+ let fpathTarget = fpath + 'tgt';
+
+ try {
+ fileIO.copyFile(fpath, fpathTarget, (err) => {
+ if (err) {
+ console.log('fileIO_copy_file_async_005 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('fileIO_copy_file_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_0500
+ * @tc.name fileIO_copy_file_async_005
+ * @tc.desc Test copyFile() interfaces. Promise.then().catch()
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_async_005', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_copy_file_async_005');
+ let fpathTarget = fpath + 'tgt';
+
+ try {
+ fileIO.copyFile(fpath, fpathTarget).then(() => {
+ expect(false).assertTrue();
+ }).catch((err) => {
+ console.log('fileIO_copy_file_async_005 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_copy_file_async_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_0600
+ * @tc.name fileIO_copy_file_async_006
+ * @tc.desc Test copyFile() interfaces. Promise.
+ * Missing Parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_async_006', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_copy_file_async_006');
+
+ try {
+ await fileIO.copyFile(fpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_copy_file_async_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_0700
+ * @tc.name fileIO_copy_file_async_007
+ * @tc.desc Test copyFile() interfaces. Callback.
+ * Missing Parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_async_007', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_copy_file_async_007');
+
+ try {
+ fileIO.copyFile(fpath, (err) => {
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ console.log('fileIO_copy_file_async_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_0800
+ * @tc.name fileIO_copy_file_async_008
+ * @tc.desc Test copyFile() interfaces. Promise.
+ * Test file copied successfully by path when mode = 0.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_async_008', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_copy_file_async_008');
+ let fpathTarget = fpath + 'tgt';
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ await fileIO.copyFile(fpath, fpathTarget, 0);
+ let stat1 = fileIO.statSync(fpath);
+ let stat2 = fileIO.statSync(fpathTarget);
+ expect(stat1.size == stat2.size).assertTrue();
+ fileIO.unlinkSync(fpath);
+ fileIO.unlinkSync(fpathTarget);
+ done();
+ } catch (e) {
+ console.log('fileIO_copy_file_async_008 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_0900
+ * @tc.name fileIO_copy_file_async_009
+ * @tc.desc Test copyFile() interfaces. Callback.
+ * Test file copied successfully by path when mode = 0.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_async_009', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_copy_file_async_009');
+ let fpathTarget = fpath + 'tgt';
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.copyFile(fpath, fpathTarget, 0, (err) => {
+ if (err) {
+ console.log('fileIO_copy_file_async_007 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ let stat1 = fileIO.statSync(fpath);
+ let stat2 = fileIO.statSync(fpathTarget);
+ expect(stat1.size == stat2.size).assertTrue();
+ fileIO.unlinkSync(fpath);
+ fileIO.unlinkSync(fpathTarget);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_copy_file_async_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_1000
+ * @tc.name fileIO_copy_file_async_010
+ * @tc.desc Test copyFile() interfaces. Callback.
+ * Don't support mode = 1.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_async_010', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_copy_file_async_010');
+ let fpathTarget = fpath + 'tgt';
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.copyFile(fpath, fpathTarget, 1, (err) => {
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_copy_file_async_010 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_1100
+ * @tc.name fileIO_copy_file_async_011
+ * @tc.desc Test copyFile() interfaces. Promise.
+ * Invalid type of mode.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_async_011', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_copy_file_async_011');
+ let fpathTarget = fpath + 'tgt';
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ await fileIO.copyFile(fpath, fpathTarget, '0');
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_copy_file_async_011 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_1200
+ * @tc.name fileIO_copy_file_async_012
+ * @tc.desc Test copyFile() interfaces. Promise.
+ * Test file copied successfully by file descriptor.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_async_012', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_copy_file_async_012');
+ let fpathTarget = fpath + 'tgt';
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let fileTgt = fileIO.openSync(fpathTarget, fileIO.OpenMode.CREATE | fileIO.OpenMode.READ_WRITE);
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ await fileIO.copyFile(file.fd, fileTgt.fd);
+ let stat1 = fileIO.statSync(fpath);
+ let stat2 = fileIO.statSync(fpathTarget);
+ expect(stat1.size == stat2.size).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.closeSync(fileTgt);
+ fileIO.unlinkSync(fpath);
+ fileIO.unlinkSync(fpathTarget);
+ done();
+ } catch (e) {
+ console.log('fileIO_copy_file_async_012 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_1300
+ * @tc.name fileIO_copy_file_async_013
+ * @tc.desc Test copyFile() interfaces. Callback.
+ * Test file copied successfully by file descriptor.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_async_013', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_copy_file_async_012');
+ let fpathTarget = fpath + 'tgt';
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let fileTgt = fileIO.openSync(fpathTarget, fileIO.OpenMode.CREATE | fileIO.OpenMode.READ_WRITE);
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ fileIO.copyFile(file.fd, fileTgt.fd, (err) => {
+ if (err) {
+ console.log('fileIO_copy_file_async_013 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ let stat1 = fileIO.statSync(fpath);
+ let stat2 = fileIO.statSync(fpathTarget);
+ expect(stat1.size == stat2.size).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.closeSync(fileTgt);
+ fileIO.unlinkSync(fpath);
+ fileIO.unlinkSync(fpathTarget);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_copy_file_async_013 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_1400
+ * @tc.name fileIO_copy_file_async_014
+ * @tc.desc Test copyFile() interfaces. Promise.
+ * Test file copied successfully by file descriptor and path when mode = 0.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_async_014', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_copy_file_async_014');
+ let fpathTarget = fpath + 'tgt';
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ expect(prepareFile(fpathTarget, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpathTarget, fileIO.OpenMode.READ_WRITE);
+ await fileIO.copyFile(fpath, file.fd, 0);
+ let stat1 = fileIO.statSync(fpath);
+ let stat2 = fileIO.statSync(fpathTarget);
+ expect(stat1.size == stat2.size).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ fileIO.unlinkSync(fpathTarget);
+ done();
+ } catch (e) {
+ console.log('fileIO_copy_file_async_014 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_1500
+ * @tc.name fileIO_copy_file_async_015
+ * @tc.desc Test copyFile() interfaces. Callback.
+ * Test file copied successfully by file descriptor and path.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_async_015', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_copy_file_async_014');
+ let fpathTarget = fpath + 'tgt';
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpathTarget, fileIO.OpenMode.CREATE | fileIO.OpenMode.READ_WRITE);
+
+ try {
+ fileIO.copyFile(fpath, file.fd, 0, (err) => {
+ if (err) {
+ console.log('fileIO_copy_file_async_013 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ let stat1 = fileIO.statSync(fpath);
+ let stat2 = fileIO.statSync(fpathTarget);
+ expect(stat1.size == stat2.size).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ fileIO.unlinkSync(fpathTarget);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_copy_file_async_015 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_1600
+ * @tc.name fileIO_copy_file_async_016
+ * @tc.desc Test copyFile() interfaces. Promise
+ * The length of file name is too long.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_async_016', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_copy_file_async_016');
+ let fpathTarget = fpath + randomString(250);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ await fileIO.copyFile(fpath, fpathTarget);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_copy_file_async_016 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900030 && e.message == 'File name too long').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_1700
+ * @tc.name fileIO_copy_file_async_017
+ * @tc.desc Test copyFile() interfaces. Callback
+ * The length of file name is too long.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_async_017', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_copy_file_async_017');
+ let fpathTarget = fpath + randomString(250);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.copyFile(fpath, fpathTarget, (err) => {
+ if (err) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_copy_file_async_017 error: {message: ' + err.message + ', code: ' + err.code);
+ expect(err.code == 13900030 && err.message == 'File name too long').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('fileIO_copy_file_async_017 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_1800
+ * @tc.name fileIO_copy_file_async_018
+ * @tc.desc Test copyFile() interfaces. Promise
+ * Use default mode = 0.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_async_018', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_copy_file_async_018');
+ let fpathTarget = fpath + 'tgt';
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ await fileIO.copyFile(fpath, fpathTarget, undefined);
+ let stat1 = fileIO.statSync(fpath);
+ let stat2 = fileIO.statSync(fpathTarget);
+ expect(stat1.size == stat2.size).assertTrue();
+ fileIO.unlinkSync(fpath);
+ fileIO.unlinkSync(fpathTarget);
+ done();
+ } catch (e) {
+ console.log('fileIO_copy_file_async_018 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_COPY_FILE_ASYNC_1900
+ * @tc.name fileIO_copy_file_async_019
+ * @tc.desc Test copyFile() interfaces. Callback
+ * Use default mode = 0.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_copy_file_async_019', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_copy_file_async_019');
+ let fpathTarget = fpath + 'tgt';
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.copyFile(fpath, fpathTarget, undefined, (err) => {
+ if (err) {
+ console.log('fileIO_copy_file_async_019 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ let stat1 = fileIO.statSync(fpath);
+ let stat2 = fileIO.statSync(fpathTarget);
+ expect(stat1.size == stat2.size).assertTrue();
+ fileIO.unlinkSync(fpath);
+ fileIO.unlinkSync(fpathTarget);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_copy_file_async_019 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+});
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/createStream.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/createStream.test.js
similarity index 97%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/createStream.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/createStream.test.js
index 0358ed638b9cdaf8a6efa2cd18cc479bf7d450f5..06cc1bbb53ae0df28877319a25d8a1c60875710d 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/createStream.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/members/createStream.test.js
@@ -1,1093 +1,1093 @@
-/*
- * Copyright (C) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the 'License');
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an 'AS IS' BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import {
- fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect,
-} from '../Common';
-
-export default function fileIOCreateStream() {
-describe('fileIO_fs_createStream', function () {
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_0000
- * @tc.name fileIO_test_create_stream_sync_000
- * @tc.desc Test createStreamSync() interface.
- * Create stream in 'r' mode and read data from this stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_sync_000', 0, async function () {
- let fpath = await nextFileName('fileIO_test_create_stream_sync_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let sr = fileIO.createStreamSync(fpath, 'r');
-
- try {
- expect(sr !== null).assertTrue();
- expect(sr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length).assertTrue();
- sr.writeSync(FILE_CONTENT);
- expect(false).assertTrue();
- } catch (e) {
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_create_stream_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_0100
- * @tc.name fileIO_test_create_stream_sync_001
- * @tc.desc Test createStreamSync() interface.
- * File does not exist.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_sync_001', 0, async function () {
- let fpath = await nextFileName('fileIO_test_create_stream_sync_001');
-
- try {
- fileIO.createStreamSync(fpath, 'r');
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_create_stream_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_0200
- * @tc.name fileIO_test_create_stream_sync_002
- * @tc.desc Test createStreamSync() interface.
- * Create stream in 'r+' mode, reading and writing data from this stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_create_stream_sync_002', 0, async function () {
- let fpath = await nextFileName('fileIO_test_create_stream_sync_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = fileIO.createStreamSync(fpath, 'r+');
- expect(sr !== null).assertTrue();
- expect(sr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length).assertTrue();
- expect(sr.writeSync(FILE_CONTENT, { offset: 0 }) == FILE_CONTENT.length).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_create_stream_sync_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_0300
- * @tc.name fileIO_test_create_stream_sync_003
- * @tc.desc Test createStreamSync() interface.
- * Create stream in 'r+' mode, file does not exist.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_sync_003', 0, async function () {
- let fpath = await nextFileName('fileIO_test_create_stream_sync_003');
-
- try {
- fileIO.createStreamSync(fpath, 'r+');
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_create_stream_sync_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_0400
- * @tc.name fileIO_test_create_stream_sync_004
- * @tc.desc Test createStreamSync() interface.
- * Invalid mode.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_sync_004', 0, async function () {
- let fpath = await nextFileName('fileIO_test_create_stream_sync_004');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.createStreamSync(fpath, 'ohos');
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_create_stream_sync_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- fileIO.unlinkSync(fpath);
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_0500
- * @tc.name fileIO_test_create_stream_sync_005
- * @tc.desc Test createStreamSync() interface.
- * Missing parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_sync_005', 0, async function () {
- let fpath = await nextFileName('fileIO_test_create_stream_sync_005');
-
- try {
- fileIO.createStreamSync(fpath);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_create_stream_sync_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_0600
- * @tc.name fileIO_test_create_stream_sync_006
- * @tc.desc Test createStreamSync() interface.
- * Create stream in 'w' mode, writing data to file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_sync_006', 0, async function () {
- let fpath = await nextFileName('fileIO_test_create_stream_sync_006');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let sw = fileIO.createStreamSync(fpath, 'w');
-
- try {
- expect(sw !== null).assertTrue();
- expect(sw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- sw.readSync(new ArrayBuffer(4096));
- expect(false).assertTrue();
- } catch (e) {
- sw.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_create_stream_sync_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_0700
- * @tc.name fileIO_test_create_stream_sync_007
- * @tc.desc Test createStreamSync() interface.
- * Create stream in 'w' mode and empty contents.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_sync_007', 0, async function () {
- let fpath = await nextFileName('fileIO_test_create_stream_sync_007');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sw = fileIO.createStreamSync(fpath, 'w');
- expect(sw !== null).assertTrue();
- expect(sw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- sw.closeSync();
-
- let sr = fileIO.createStreamSync(fpath, 'r');
- expect(sr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_create_stream_sync_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_0800
- * @tc.name fileIO_test_create_stream_sync_008
- * @tc.desc Test createStreamSync() interface.
- * Create stream in 'w' mode, creat a file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_sync_008', 0, async function () {
- let fpath = await nextFileName('fileIO_test_create_stream_sync_008');
-
- try {
- let sw = fileIO.createStreamSync(fpath, 'w');
- expect(sw !== null).assertTrue();
- expect(sw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- sw.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_create_stream_sync_008 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_0900
- * @tc.name fileIO_test_create_stream_sync_009
- * @tc.desc Test createStreamSync() interface.
- * Create stream in 'w+' mode and empty contents.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_sync_009', 0, async function () {
- let fpath = await nextFileName('fileIO_test_create_stream_sync_009');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sw = fileIO.createStreamSync(fpath, 'w+');
- expect(sw !== null).assertTrue();
- expect(sw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- expect(sw.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length).assertTrue();
- sw.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_create_stream_sync_009 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_1000
- * @tc.name fileIO_test_create_stream_sync_010
- * @tc.desc Test createStreamSync() interface.
- * Create stream in 'w+' mode and creat a file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_sync_010', 0, async function () {
- let fpath = await nextFileName('fileIO_test_create_stream_sync_010');
-
- try {
- let sw = fileIO.createStreamSync(fpath, 'w+');
- expect(sw !== null).assertTrue();
- expect(sw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- expect(sw.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length).assertTrue();
- sw.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_create_stream_sync_010 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_1100
- * @tc.name fileIO_test_create_stream_sync_011
- * @tc.desc Test createStreamSync() interface.
- * Create stream in 'a' mode and append contents.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_sync_011', 0, async function () {
- let fpath = await nextFileName('fileIO_test_create_stream_sync_011');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sa = fileIO.createStreamSync(fpath, 'a');
- expect(sa !== null).assertTrue();
- expect(sa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- sa.closeSync();
-
- let sr = fileIO.createStreamSync(fpath, 'r');
- expect(sr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length * 2).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_create_stream_sync_011 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_1200
- * @tc.name fileIO_test_create_stream_sync_012
- * @tc.desc Test createStreamSync() interface.
- * Create stream in 'a' mode and creat a file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_sync_012', 0, async function () {
- let fpath = await nextFileName('fileIO_test_create_stream_sync_012');
-
- try {
- let sa = fileIO.createStreamSync(fpath, 'a');
- expect(sa !== null).assertTrue();
- expect(sa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- sa.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_create_stream_sync_012 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_1300
- * @tc.name fileIO_test_create_stream_sync_013
- * @tc.desc Test createStreamSync() interface.
- * Create stream in 'a' mode and write data to file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_sync_013', 0, async function () {
- let fpath = await nextFileName('fileIO_test_create_stream_sync_013');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let sa = fileIO.createStreamSync(fpath, 'a');
-
- try {
- expect(sa !== null).assertTrue();
- expect(sa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- sa.readSync(new ArrayBuffer(4096));
- expect(false).assertTrue();
- } catch (e) {
- sa.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_create_stream_sync_013 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_1400
- * @tc.name fileIO_test_create_stream_sync_014
- * @tc.desc Test createStreamSync() interface.
- * Create stream in 'a+' mode and append contents.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_sync_014', 0, async function () {
- let fpath = await nextFileName('fileIO_test_create_stream_sync_014');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sa = fileIO.createStreamSync(fpath, 'a+');
- expect(sa !== null).assertTrue();
- expect(sa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- expect(sa.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length * 2).assertTrue();
- sa.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_create_stream_sync_014 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_1500
- * @tc.name fileIO_test_create_stream_sync_015
- * @tc.desc Test createStreamSync() interface.
- * Create stream in 'a+' mode and creat a file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_sync_015', 0, async function () {
- let fpath = await nextFileName('fileIO_test_create_stream_sync_015');
-
- try {
- let sa = fileIO.createStreamSync(fpath, 'a+');
- expect(sa !== null).assertTrue();
- expect(sa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- expect(sa.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length).assertTrue();
- sa.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_create_stream_sync_015 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_0000
- * @tc.name fileIO_test_create_stream_async_000
- * @tc.desc Test createStream() interfaces. Promise.
- * Create stream in 'r' mode and read data from stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_async_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_create_stream_async_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let sr = await fileIO.createStream(fpath, 'r');
-
- try {
- expect(sr !== null).assertTrue();
- expect(sr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length).assertTrue();
- sr.writeSync(FILE_CONTENT);
- expect(false).assertTrue();
- } catch (e) {
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_create_stream_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_0100
- * @tc.name fileIO_test_create_stream_async_001
- * @tc.desc Test createStream() interfaces. Callback.
- * Create stream in 'r' mode and read data from stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_async_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_create_stream_async_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.createStream(fpath, 'r', (err, sr) => {
- if (err) {
- console.log('fileIO_test_create_stream_async_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(sr !== null).assertTrue();
- expect(sr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length).assertTrue();
- sr.write(FILE_CONTENT, (err) => {
- if (err) {
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- console.log(
- 'fileIO_test_create_stream_async_001 error: {message: ' + err.message + ', code: ' + err.code + '}'
- );
- expect(err.code == 13900005 && err.message == 'I/O error').assertTrue();
- done();
- } else {
- expect(false).assertTrue();
- }
- });
- });
- } catch (e) {
- console.log('fileIO_test_create_stream_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_0200
- * @tc.name fileIO_test_create_stream_async_002
- * @tc.desc Test createStream() interfaces. Promise.
- * Create stream in 'r' mode, file does not exist.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_async_002', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_create_stream_async_002');
-
- try {
- await fileIO.createStream(fpath, 'r');
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_create_stream_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_0300
- * @tc.name fileIO_test_create_stream_async_003
- * @tc.desc Test createStream() interfaces. Callback.
- * Create stream in 'r' mode, file does not exist.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_async_003', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_create_stream_async_003');
-
- try {
- fileIO.createStream(fpath, 'r', (err) => {
- if (err) {
- console.log('fileIO_test_create_stream_async_003 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('fileIO_test_create_stream_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_0400
- * @tc.name fileIO_test_create_stream_async_004
- * @tc.desc Test createStream() interfaces. Promise.
- * Create stream in 'r+' mode, reading and writing data from this stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 1
- * @tc.require
- */
- it('fileIO_test_create_stream_async_004', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_create_stream_async_004');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sr = await fileIO.createStream(fpath, 'r+');
- expect(sr !== null).assertTrue();
- expect(sr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length).assertTrue();
- expect(sr.writeSync(FILE_CONTENT, { offset: 0 }) == FILE_CONTENT.length).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_create_stream_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_0500
- * @tc.name fileIO_test_create_stream_async_005
- * @tc.desc Test createStream() interfaces. Callback.
- * Create stream in 'r+' mode, reading and writing data from this stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 1
- * @tc.require
- */
- it('fileIO_test_create_stream_async_005', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_create_stream_async_005');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.createStream(fpath, 'r+', (err, sr) => {
- if (err) {
- console.log('fileIO_test_create_stream_async_005 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(sr !== null).assertTrue();
- expect(sr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length).assertTrue();
- expect(sr.writeSync(FILE_CONTENT, { offset: 0 }) == FILE_CONTENT.length).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_create_stream_async_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_0600
- * @tc.name fileIO_test_create_stream_async_006
- * @tc.desc Test createStream() interfaces. Promise.
- * Create stream in 'r+' mode, File does not exist.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_async_006', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_create_stream_async_006');
-
- try {
- await fileIO.createStream(fpath, 'r+');
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_create_stream_async_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_0700
- * @tc.name fileIO_test_create_stream_async_007
- * @tc.desc Test createStream() interfaces. Callback.
- * Create stream in 'r+' mode, file does not exist.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_async_007', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_create_stream_async_007');
-
- try {
- fileIO.createStream(fpath, 'r+', (err) => {
- console.log('fileIO_test_create_stream_async_007 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
- done();
- });
- } catch (e) {
- console.log('fileIO_test_create_stream_async_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_0800
- * @tc.name fileIO_test_create_stream_async_008
- * @tc.desc Test createStream() interfaces. Promise.
- * Invalid mode.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_async_008', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_create_stream_async_008');
-
- try {
- await fileIO.createStream(fpath, 'ohos');
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_create_stream_async_008 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_0900
- * @tc.name fileIO_test_create_stream_async_009
- * @tc.desc Test createStream() interfaces. Promise.
- * Missing parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_async_009', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_create_stream_async_009');
-
- try {
- await fileIO.createStream(fpath);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_create_stream_async_009 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
-
- /**
- * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_1000
- * @tc.name fileIO_test_create_stream_async_010
- * @tc.desc Test createStream() interfaces. Promise.
- * Create stream in 'w' mode and write data to file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_async_010', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_create_stream_async_010');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sw = await fileIO.createStream(fpath, 'w');
- expect(sw !== null).assertTrue();
- expect(sw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- sw.closeSync();
-
- let sr = fileIO.createStreamSync(fpath, 'r');
- expect(sr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_create_stream_async_010 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_1100
- * @tc.name fileIO_test_create_stream_async_011
- * @tc.desc Test createStream() interfaces. Promise.
- * Create stream in 'w' mode, can't to read data from this stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_async_011', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_create_stream_async_011');
- let sw = await fileIO.createStream(fpath, 'w');
-
- try {
- expect(sw !== null).assertTrue();
- expect(sw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- sw.readSync(new ArrayBuffer(4096));
- expect(false).assertTrue();
- } catch (e) {
- sw.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_create_stream_async_011 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_1200
- * @tc.name fileIO_test_create_stream_async_012
- * @tc.desc Test createStream() interfaces. Callback.
- * Create stream in 'w' mode, can't to read data from this stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_async_012', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_create_stream_async_012');
-
- try {
- fileIO.createStream(fpath, 'w', (err, sw) => {
- if (err) {
- console.log('fileIO_test_create_stream_async_012 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(sw !== null).assertTrue();
- expect(sw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- sw.read(new ArrayBuffer(4096), (err) => {
- if (err) {
- sw.closeSync();
- fileIO.unlinkSync(fpath);
- console.log(
- 'fileIO_test_create_stream_async_012 error: {message: ' + err.message + ', code: ' + err.code + '}'
- );
- expect(err.code == 13900005 && err.message == 'I/O error').assertTrue();
- done();
- } else {
- expect(false).assertTrue();
- }
- });
- });
- } catch (e) {
- console.log('fileIO_test_create_stream_async_012 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_1300
- * @tc.name fileIO_test_create_stream_async_013
- * @tc.desc Test createStream() interfaces. Promise.
- * Create stream in 'w+' mode and write/read data from this stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_async_013', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_create_stream_async_013');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sw = await fileIO.createStream(fpath, 'w+');
- expect(sw !== null).assertTrue();
- expect(sw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- expect(sw.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length).assertTrue();
- sw.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_create_stream_async_013 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_1400
- * @tc.name fileIO_test_create_stream_async_014
- * @tc.desc Test createStream() interfaces. Promise.
- * Create stream in 'w+' mode and creat a file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_async_014', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_create_stream_async_014');
-
- try {
- let sw = await fileIO.createStream(fpath, 'w+');
- expect(sw !== null).assertTrue();
- expect(sw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- expect(sw.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length).assertTrue();
- sw.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_create_stream_async_014 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_1500
- * @tc.name fileIO_test_create_stream_async_015
- * @tc.desc Test createStream() interfaces. Callback.
- * Create stream in 'w+' mode and creat a file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_async_015', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_create_stream_async_015');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.createStream(fpath, 'w+', (err, sw) => {
- if (err) {
- console.log('fileIO_test_create_stream_async_015 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(sw !== null).assertTrue();
- expect(sw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- expect(sw.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length).assertTrue();
- sw.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_create_stream_async_015 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_1600
- * @tc.name fileIO_test_create_stream_async_016
- * @tc.desc Test createStream() interfaces. Promise.
- * Create stream in 'a' mode and append content to file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_async_016', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_create_stream_async_016');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sa = await fileIO.createStream(fpath, 'a');
- expect(sa !== null).assertTrue();
- expect(sa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- sa.closeSync();
-
- let sr = fileIO.createStreamSync(fpath, 'r');
- expect(sr.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length * 2).assertTrue();
- sr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_create_stream_async_016 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_1700
- * @tc.name fileIO_test_create_stream_async_017
- * @tc.desc Test createStream() interfaces. Promise.
- * Create stream in 'a' mode and can't to read data from stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_async_017', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_create_stream_async_017');
- let sa = await fileIO.createStream(fpath, 'a');
-
- try {
- expect(sa !== null).assertTrue();
- expect(sa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- sa.readSync(new ArrayBuffer(4096));
- expect(false).assertTrue();
- } catch (e) {
- sa.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_create_stream_async_017 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_1800
- * @tc.name fileIO_test_create_stream_async_018
- * @tc.desc Test createStream() interfaces. Callback.
- * Create stream in 'a' mode and can't to read data from stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_async_018', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_create_stream_async_018');
-
- try {
- fileIO.createStream(fpath, 'a', (err, sa) => {
- if (err) {
- console.log('fileIO_test_create_stream_async_018 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(sa !== null).assertTrue();
- expect(sa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- sa.read(new ArrayBuffer(4096), (err) => {
- if (err) {
- sa.closeSync();
- fileIO.unlinkSync(fpath);
- console.log(
- 'fileIO_test_create_stream_async_018 error: {message: ' + err.message + ', code: ' + err.code + '}'
- );
- expect(err.code == 13900005 && err.message == 'I/O error').assertTrue();
- done();
- } else {
- expect(false).assertTrue();
- }
- })
- });
- } catch (e) {
- console.log('fileIO_test_create_stream_async_018 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_1900
- * @tc.name fileIO_test_create_stream_async_019
- * @tc.desc Test createStream() interfaces. Promise.
- * Create stream in 'a+' mode and append content to file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_async_019', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_create_stream_async_019');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let sa = await fileIO.createStream(fpath, 'a+');
- expect(sa !== null).assertTrue();
- expect(sa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- expect(sa.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length * 2).assertTrue();
- sa.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_create_stream_async_019 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_2000
- * @tc.name fileIO_test_create_stream_async_020
- * @tc.desc Test createStream() interfaces. Promise.
- * Create stream in 'a+' mode and creat a file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_async_020', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_create_stream_async_019');
-
- try {
- let sa = await fileIO.createStream(fpath, 'a+');
- expect(sa !== null).assertTrue();
- expect(sa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- expect(sa.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length).assertTrue();
- sa.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_create_stream_async_020 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_2100
- * @tc.name fileIO_test_create_stream_async_021
- * @tc.desc Test createStream() interfaces. Callback.
- * Create stream in 'a+' mode and append content to file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_create_stream_async_021', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_create_stream_async_021');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.createStream(fpath, 'a+', (err, sa) => {
- if (err) {
- console.log('fileIO_test_create_stream_async_021 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(sa !== null).assertTrue();
- expect(sa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- expect(sa.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length * 2).assertTrue();
- sa.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_create_stream_async_021 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-});
-}
+/*
+ * Copyright (C) 2023 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import {
+ fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect,
+} from '../Common';
+
+export default function fileIOCreateStream() {
+describe('fileIO_fs_createStream', function () {
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_0000
+ * @tc.name fileIO_test_create_stream_sync_000
+ * @tc.desc Test createStreamSync() interface.
+ * Create stream in 'r' mode and read data from this stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_sync_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_create_stream_sync_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let sr = fileIO.createStreamSync(fpath, 'r');
+
+ try {
+ expect(sr !== null).assertTrue();
+ expect(sr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length).assertTrue();
+ sr.writeSync(FILE_CONTENT);
+ expect(false).assertTrue();
+ } catch (e) {
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_create_stream_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_0100
+ * @tc.name fileIO_test_create_stream_sync_001
+ * @tc.desc Test createStreamSync() interface.
+ * File does not exist.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_sync_001', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_create_stream_sync_001');
+
+ try {
+ fileIO.createStreamSync(fpath, 'r');
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_create_stream_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_0200
+ * @tc.name fileIO_test_create_stream_sync_002
+ * @tc.desc Test createStreamSync() interface.
+ * Create stream in 'r+' mode, reading and writing data from this stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_sync_002', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_create_stream_sync_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = fileIO.createStreamSync(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ expect(sr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length).assertTrue();
+ expect(sr.writeSync(FILE_CONTENT, { offset: 0 }) == FILE_CONTENT.length).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_create_stream_sync_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_0300
+ * @tc.name fileIO_test_create_stream_sync_003
+ * @tc.desc Test createStreamSync() interface.
+ * Create stream in 'r+' mode, file does not exist.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_sync_003', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_create_stream_sync_003');
+
+ try {
+ fileIO.createStreamSync(fpath, 'r+');
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_create_stream_sync_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_0400
+ * @tc.name fileIO_test_create_stream_sync_004
+ * @tc.desc Test createStreamSync() interface.
+ * Invalid mode.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_sync_004', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_create_stream_sync_004');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.createStreamSync(fpath, 'ohos');
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_create_stream_sync_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ fileIO.unlinkSync(fpath);
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_0500
+ * @tc.name fileIO_test_create_stream_sync_005
+ * @tc.desc Test createStreamSync() interface.
+ * Missing parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_sync_005', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_create_stream_sync_005');
+
+ try {
+ fileIO.createStreamSync(fpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_create_stream_sync_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_0600
+ * @tc.name fileIO_test_create_stream_sync_006
+ * @tc.desc Test createStreamSync() interface.
+ * Create stream in 'w' mode, writing data to file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_sync_006', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_create_stream_sync_006');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let sw = fileIO.createStreamSync(fpath, 'w');
+
+ try {
+ expect(sw !== null).assertTrue();
+ expect(sw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ sw.readSync(new ArrayBuffer(4096));
+ expect(false).assertTrue();
+ } catch (e) {
+ sw.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_create_stream_sync_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_0700
+ * @tc.name fileIO_test_create_stream_sync_007
+ * @tc.desc Test createStreamSync() interface.
+ * Create stream in 'w' mode and empty contents.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_sync_007', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_create_stream_sync_007');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sw = fileIO.createStreamSync(fpath, 'w');
+ expect(sw !== null).assertTrue();
+ expect(sw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ sw.closeSync();
+
+ let sr = fileIO.createStreamSync(fpath, 'r');
+ expect(sr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_create_stream_sync_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_0800
+ * @tc.name fileIO_test_create_stream_sync_008
+ * @tc.desc Test createStreamSync() interface.
+ * Create stream in 'w' mode, creat a file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_sync_008', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_create_stream_sync_008');
+
+ try {
+ let sw = fileIO.createStreamSync(fpath, 'w');
+ expect(sw !== null).assertTrue();
+ expect(sw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ sw.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_create_stream_sync_008 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_0900
+ * @tc.name fileIO_test_create_stream_sync_009
+ * @tc.desc Test createStreamSync() interface.
+ * Create stream in 'w+' mode and empty contents.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_sync_009', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_create_stream_sync_009');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sw = fileIO.createStreamSync(fpath, 'w+');
+ expect(sw !== null).assertTrue();
+ expect(sw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ expect(sw.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length).assertTrue();
+ sw.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_create_stream_sync_009 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_1000
+ * @tc.name fileIO_test_create_stream_sync_010
+ * @tc.desc Test createStreamSync() interface.
+ * Create stream in 'w+' mode and creat a file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_sync_010', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_create_stream_sync_010');
+
+ try {
+ let sw = fileIO.createStreamSync(fpath, 'w+');
+ expect(sw !== null).assertTrue();
+ expect(sw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ expect(sw.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length).assertTrue();
+ sw.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_create_stream_sync_010 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_1100
+ * @tc.name fileIO_test_create_stream_sync_011
+ * @tc.desc Test createStreamSync() interface.
+ * Create stream in 'a' mode and append contents.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_sync_011', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_create_stream_sync_011');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sa = fileIO.createStreamSync(fpath, 'a');
+ expect(sa !== null).assertTrue();
+ expect(sa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ sa.closeSync();
+
+ let sr = fileIO.createStreamSync(fpath, 'r');
+ expect(sr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length * 2).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_create_stream_sync_011 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_1200
+ * @tc.name fileIO_test_create_stream_sync_012
+ * @tc.desc Test createStreamSync() interface.
+ * Create stream in 'a' mode and creat a file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_sync_012', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_create_stream_sync_012');
+
+ try {
+ let sa = fileIO.createStreamSync(fpath, 'a');
+ expect(sa !== null).assertTrue();
+ expect(sa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ sa.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_create_stream_sync_012 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_1300
+ * @tc.name fileIO_test_create_stream_sync_013
+ * @tc.desc Test createStreamSync() interface.
+ * Create stream in 'a' mode and write data to file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_sync_013', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_create_stream_sync_013');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let sa = fileIO.createStreamSync(fpath, 'a');
+
+ try {
+ expect(sa !== null).assertTrue();
+ expect(sa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ sa.readSync(new ArrayBuffer(4096));
+ expect(false).assertTrue();
+ } catch (e) {
+ sa.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_create_stream_sync_013 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_1400
+ * @tc.name fileIO_test_create_stream_sync_014
+ * @tc.desc Test createStreamSync() interface.
+ * Create stream in 'a+' mode and append contents.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_sync_014', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_create_stream_sync_014');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sa = fileIO.createStreamSync(fpath, 'a+');
+ expect(sa !== null).assertTrue();
+ expect(sa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ expect(sa.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length * 2).assertTrue();
+ sa.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_create_stream_sync_014 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STREAM_CREATESTREAM_SYNC_1500
+ * @tc.name fileIO_test_create_stream_sync_015
+ * @tc.desc Test createStreamSync() interface.
+ * Create stream in 'a+' mode and creat a file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_sync_015', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_create_stream_sync_015');
+
+ try {
+ let sa = fileIO.createStreamSync(fpath, 'a+');
+ expect(sa !== null).assertTrue();
+ expect(sa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ expect(sa.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length).assertTrue();
+ sa.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_create_stream_sync_015 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_0000
+ * @tc.name fileIO_test_create_stream_async_000
+ * @tc.desc Test createStream() interfaces. Promise.
+ * Create stream in 'r' mode and read data from stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_async_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_create_stream_async_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let sr = await fileIO.createStream(fpath, 'r');
+
+ try {
+ expect(sr !== null).assertTrue();
+ expect(sr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length).assertTrue();
+ sr.writeSync(FILE_CONTENT);
+ expect(false).assertTrue();
+ } catch (e) {
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_create_stream_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_0100
+ * @tc.name fileIO_test_create_stream_async_001
+ * @tc.desc Test createStream() interfaces. Callback.
+ * Create stream in 'r' mode and read data from stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_async_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_create_stream_async_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.createStream(fpath, 'r', (err, sr) => {
+ if (err) {
+ console.log('fileIO_test_create_stream_async_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(sr !== null).assertTrue();
+ expect(sr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length).assertTrue();
+ sr.write(FILE_CONTENT, (err) => {
+ if (err) {
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log(
+ 'fileIO_test_create_stream_async_001 error: {message: ' + err.message + ', code: ' + err.code + '}'
+ );
+ expect(err.code == 13900005 && err.message == 'I/O error').assertTrue();
+ done();
+ } else {
+ expect(false).assertTrue();
+ }
+ });
+ });
+ } catch (e) {
+ console.log('fileIO_test_create_stream_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_0200
+ * @tc.name fileIO_test_create_stream_async_002
+ * @tc.desc Test createStream() interfaces. Promise.
+ * Create stream in 'r' mode, file does not exist.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_async_002', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_create_stream_async_002');
+
+ try {
+ await fileIO.createStream(fpath, 'r');
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_create_stream_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_0300
+ * @tc.name fileIO_test_create_stream_async_003
+ * @tc.desc Test createStream() interfaces. Callback.
+ * Create stream in 'r' mode, file does not exist.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_async_003', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_create_stream_async_003');
+
+ try {
+ fileIO.createStream(fpath, 'r', (err) => {
+ if (err) {
+ console.log('fileIO_test_create_stream_async_003 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('fileIO_test_create_stream_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_0400
+ * @tc.name fileIO_test_create_stream_async_004
+ * @tc.desc Test createStream() interfaces. Promise.
+ * Create stream in 'r+' mode, reading and writing data from this stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 1
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_async_004', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_create_stream_async_004');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sr = await fileIO.createStream(fpath, 'r+');
+ expect(sr !== null).assertTrue();
+ expect(sr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length).assertTrue();
+ expect(sr.writeSync(FILE_CONTENT, { offset: 0 }) == FILE_CONTENT.length).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_create_stream_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_0500
+ * @tc.name fileIO_test_create_stream_async_005
+ * @tc.desc Test createStream() interfaces. Callback.
+ * Create stream in 'r+' mode, reading and writing data from this stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 1
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_async_005', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_create_stream_async_005');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.createStream(fpath, 'r+', (err, sr) => {
+ if (err) {
+ console.log('fileIO_test_create_stream_async_005 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(sr !== null).assertTrue();
+ expect(sr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length).assertTrue();
+ expect(sr.writeSync(FILE_CONTENT, { offset: 0 }) == FILE_CONTENT.length).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_create_stream_async_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_0600
+ * @tc.name fileIO_test_create_stream_async_006
+ * @tc.desc Test createStream() interfaces. Promise.
+ * Create stream in 'r+' mode, File does not exist.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_async_006', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_create_stream_async_006');
+
+ try {
+ await fileIO.createStream(fpath, 'r+');
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_create_stream_async_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_0700
+ * @tc.name fileIO_test_create_stream_async_007
+ * @tc.desc Test createStream() interfaces. Callback.
+ * Create stream in 'r+' mode, file does not exist.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_async_007', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_create_stream_async_007');
+
+ try {
+ fileIO.createStream(fpath, 'r+', (err) => {
+ console.log('fileIO_test_create_stream_async_007 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_create_stream_async_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_0800
+ * @tc.name fileIO_test_create_stream_async_008
+ * @tc.desc Test createStream() interfaces. Promise.
+ * Invalid mode.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_async_008', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_create_stream_async_008');
+
+ try {
+ await fileIO.createStream(fpath, 'ohos');
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_create_stream_async_008 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_0900
+ * @tc.name fileIO_test_create_stream_async_009
+ * @tc.desc Test createStream() interfaces. Promise.
+ * Missing parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_async_009', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_create_stream_async_009');
+
+ try {
+ await fileIO.createStream(fpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_create_stream_async_009 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_1000
+ * @tc.name fileIO_test_create_stream_async_010
+ * @tc.desc Test createStream() interfaces. Promise.
+ * Create stream in 'w' mode and write data to file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_async_010', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_create_stream_async_010');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sw = await fileIO.createStream(fpath, 'w');
+ expect(sw !== null).assertTrue();
+ expect(sw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ sw.closeSync();
+
+ let sr = fileIO.createStreamSync(fpath, 'r');
+ expect(sr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_create_stream_async_010 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_1100
+ * @tc.name fileIO_test_create_stream_async_011
+ * @tc.desc Test createStream() interfaces. Promise.
+ * Create stream in 'w' mode, can't to read data from this stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_async_011', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_create_stream_async_011');
+ let sw = await fileIO.createStream(fpath, 'w');
+
+ try {
+ expect(sw !== null).assertTrue();
+ expect(sw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ sw.readSync(new ArrayBuffer(4096));
+ expect(false).assertTrue();
+ } catch (e) {
+ sw.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_create_stream_async_011 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_1200
+ * @tc.name fileIO_test_create_stream_async_012
+ * @tc.desc Test createStream() interfaces. Callback.
+ * Create stream in 'w' mode, can't to read data from this stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_async_012', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_create_stream_async_012');
+
+ try {
+ fileIO.createStream(fpath, 'w', (err, sw) => {
+ if (err) {
+ console.log('fileIO_test_create_stream_async_012 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(sw !== null).assertTrue();
+ expect(sw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ sw.read(new ArrayBuffer(4096), (err) => {
+ if (err) {
+ sw.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log(
+ 'fileIO_test_create_stream_async_012 error: {message: ' + err.message + ', code: ' + err.code + '}'
+ );
+ expect(err.code == 13900005 && err.message == 'I/O error').assertTrue();
+ done();
+ } else {
+ expect(false).assertTrue();
+ }
+ });
+ });
+ } catch (e) {
+ console.log('fileIO_test_create_stream_async_012 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_1300
+ * @tc.name fileIO_test_create_stream_async_013
+ * @tc.desc Test createStream() interfaces. Promise.
+ * Create stream in 'w+' mode and write/read data from this stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_async_013', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_create_stream_async_013');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sw = await fileIO.createStream(fpath, 'w+');
+ expect(sw !== null).assertTrue();
+ expect(sw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ expect(sw.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length).assertTrue();
+ sw.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_create_stream_async_013 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_1400
+ * @tc.name fileIO_test_create_stream_async_014
+ * @tc.desc Test createStream() interfaces. Promise.
+ * Create stream in 'w+' mode and creat a file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_async_014', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_create_stream_async_014');
+
+ try {
+ let sw = await fileIO.createStream(fpath, 'w+');
+ expect(sw !== null).assertTrue();
+ expect(sw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ expect(sw.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length).assertTrue();
+ sw.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_create_stream_async_014 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_1500
+ * @tc.name fileIO_test_create_stream_async_015
+ * @tc.desc Test createStream() interfaces. Callback.
+ * Create stream in 'w+' mode and creat a file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_async_015', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_create_stream_async_015');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.createStream(fpath, 'w+', (err, sw) => {
+ if (err) {
+ console.log('fileIO_test_create_stream_async_015 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(sw !== null).assertTrue();
+ expect(sw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ expect(sw.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length).assertTrue();
+ sw.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_create_stream_async_015 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_1600
+ * @tc.name fileIO_test_create_stream_async_016
+ * @tc.desc Test createStream() interfaces. Promise.
+ * Create stream in 'a' mode and append content to file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_async_016', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_create_stream_async_016');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sa = await fileIO.createStream(fpath, 'a');
+ expect(sa !== null).assertTrue();
+ expect(sa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ sa.closeSync();
+
+ let sr = fileIO.createStreamSync(fpath, 'r');
+ expect(sr.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length * 2).assertTrue();
+ sr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_create_stream_async_016 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_1700
+ * @tc.name fileIO_test_create_stream_async_017
+ * @tc.desc Test createStream() interfaces. Promise.
+ * Create stream in 'a' mode and can't to read data from stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_async_017', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_create_stream_async_017');
+ let sa = await fileIO.createStream(fpath, 'a');
+
+ try {
+ expect(sa !== null).assertTrue();
+ expect(sa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ sa.readSync(new ArrayBuffer(4096));
+ expect(false).assertTrue();
+ } catch (e) {
+ sa.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_create_stream_async_017 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_1800
+ * @tc.name fileIO_test_create_stream_async_018
+ * @tc.desc Test createStream() interfaces. Callback.
+ * Create stream in 'a' mode and can't to read data from stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_async_018', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_create_stream_async_018');
+
+ try {
+ fileIO.createStream(fpath, 'a', (err, sa) => {
+ if (err) {
+ console.log('fileIO_test_create_stream_async_018 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(sa !== null).assertTrue();
+ expect(sa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ sa.read(new ArrayBuffer(4096), (err) => {
+ if (err) {
+ sa.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log(
+ 'fileIO_test_create_stream_async_018 error: {message: ' + err.message + ', code: ' + err.code + '}'
+ );
+ expect(err.code == 13900005 && err.message == 'I/O error').assertTrue();
+ done();
+ } else {
+ expect(false).assertTrue();
+ }
+ })
+ });
+ } catch (e) {
+ console.log('fileIO_test_create_stream_async_018 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_1900
+ * @tc.name fileIO_test_create_stream_async_019
+ * @tc.desc Test createStream() interfaces. Promise.
+ * Create stream in 'a+' mode and append content to file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_async_019', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_create_stream_async_019');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let sa = await fileIO.createStream(fpath, 'a+');
+ expect(sa !== null).assertTrue();
+ expect(sa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ expect(sa.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length * 2).assertTrue();
+ sa.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_create_stream_async_019 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_2000
+ * @tc.name fileIO_test_create_stream_async_020
+ * @tc.desc Test createStream() interfaces. Promise.
+ * Create stream in 'a+' mode and creat a file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_async_020', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_create_stream_async_019');
+
+ try {
+ let sa = await fileIO.createStream(fpath, 'a+');
+ expect(sa !== null).assertTrue();
+ expect(sa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ expect(sa.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length).assertTrue();
+ sa.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_create_stream_async_020 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_CREATE_CREATESTREAM_ASYNC_2100
+ * @tc.name fileIO_test_create_stream_async_021
+ * @tc.desc Test createStream() interfaces. Callback.
+ * Create stream in 'a+' mode and append content to file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_create_stream_async_021', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_create_stream_async_021');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.createStream(fpath, 'a+', (err, sa) => {
+ if (err) {
+ console.log('fileIO_test_create_stream_async_021 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(sa !== null).assertTrue();
+ expect(sa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ expect(sa.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length * 2).assertTrue();
+ sa.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_create_stream_async_021 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+});
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/fdatasync.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/fdatasync.test.js
similarity index 97%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/fdatasync.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/fdatasync.test.js
index c7e43d4a4f4dd0d0cfcbcc778bad5d46956e8f2f..688e82a1220aa73873cbcf00d5a1f4b2a133c729 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/fdatasync.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/members/fdatasync.test.js
@@ -1,294 +1,294 @@
-/*
- * Copyright (C) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the 'License');
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an 'AS IS' BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import {
- fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect,
-} from '../Common';
-
-export default function fileIOFdatasync() {
- describe('fileIO_fs_fdatasync', async function () {
-
- /**
- * @tc.number SUB_DF_FILEIO_FDATASYNC_SYNC_0000
- * @tc.name fileIO_test_fdatasync_sync_000
- * @tc.desc Test fdatasyncSync() interfaces.
- * Open the file in read-write mode, and synchronize the file content data.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_fdatasync_sync_000', 0, async function () {
- let fpath = await nextFileName('fileIO_test_fdatasync_sync_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- fileIO.fdatasyncSync(file.fd);
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_fdatasync_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDATASYNC_SYNC_0100
- * @tc.name fileIO_test_fdatasync_sync_001
- * @tc.desc Test fdatasyncSync() interfaces. Invalid fd parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdatasync_sync_001', 0, async function () {
-
- try {
- fileIO.fdatasyncSync(-1);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_fdatasync_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900008 && e.message == 'Bad file descriptor').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDATASYNC_SYNC_0200
- * @tc.name fileIO_test_fdatasync_sync_002
- * @tc.desc Test fdatasyncSync() interfaces. Missing parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdatasync_sync_002', 0, async function () {
-
- try {
- fileIO.fdatasyncSync();
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_fdatasync_sync_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDATASYNC_ASYNC_0000
- * @tc.name fileIO_test_fdatasync_async_000
- * @tc.desc Test fdatasync() interfaces. Callback.
- * Open the file in read-write mode, and synchronize the file content data.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_fdatasync_async_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_fdatasync_async_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- fileIO.fdatasync(file.fd, (err) => {
- if (err) {
- console.log('fileIO_test_fdatasync_async_000 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_fdatasync_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDATASYNC_ASYNC_0100
- * @tc.name fileIO_test_fdatasync_async_001
- * @tc.desc Test fdatasync() interfaces. Promise.then().catch().
- * Open the file in read-write mode, and synchronize the file content data.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdatasync_async_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_fdatasync_async_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- fileIO.fdatasync(file.fd).then(() => {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- }).catch((err) => {
- console.log('fileIO_test_fdatasync_async_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- });
- } catch (e) {
- console.log('fileIO_test_fdatasync_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDATASYNC_ASYNC_0200
- * @tc.name fileIO_test_fdatasync_async_002
- * @tc.desc Test fdatasync() interfaces. await Promise.
- * Open the file in read-write mode, and synchronize the file content data.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdatasync_async_002', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_fdatasync_async_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- await fileIO.fdatasync(file.fd);
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_fdatasync_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDATASYNC_ASYNC_0300
- * @tc.name fileIO_test_fdatasync_async_003
- * @tc.desc Test fdatasync() interfaces. await Promise.
- * Invalid fd parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdatasync_async_003', 0, async function (done) {
-
- try {
- await fileIO.fdatasync(-1);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_fdatasync_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900008 && e.message == 'Bad file descriptor').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDATASYNC_ASYNC_0400
- * @tc.name fileIO_test_fdatasync_async_004
- * @tc.desc Test fdatasync() interfaces. Callback.
- * Invalid fd parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdatasync_async_004', 0, async function (done) {
-
- try {
- fileIO.fdatasync(-1, (err) => {
- if (err) {
- console.log('fileIO_test_fdatasync_async_004 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900008 && err.message == 'Bad file descriptor').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('fileIO_test_fdatasync_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDATASYNC_ASYNC_0500
- * @tc.name fileIO_test_fdatasync_async_005
- * @tc.desc Test fdatasync() interfaces. Promise.then().catch()
- * Invalid fd parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdatasync_async_005', 0, async function (done) {
-
- try {
- fileIO.fdatasync(-1).then(() => {
- expect(false).assertTrue();
- }).catch((err) => {
- console.log('fileIO_test_fdatasync_async_005 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900008 && err.message == 'Bad file descriptor').assertTrue();
- done();
- });
- } catch (e) {
- console.log('fileIO_test_fdatasync_async_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDATASYNC_ASYNC_0600
- * @tc.name fileIO_test_fdatasync_async_006
- * @tc.desc Test fdatasync() interfaces. Promise.
- * Missing parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdatasync_async_006', 0, async function (done) {
-
- try {
- await fileIO.fdatasync();
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_fdatasync_async_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDATASYNC_ASYNC_0700
- * @tc.name fileIO_test_fdatasync_async_007
- * @tc.desc Test fdatasync() interfaces. Callback.
- * Missing parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdatasync_async_007', 0, async function (done) {
-
- try {
- fileIO.fdatasync((err) => {
- expect(false).assertTrue();
- });
- } catch (e) {
- console.log('fileIO_test_fdatasync_async_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-})
-}
+/*
+ * Copyright (C) 2023 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import {
+ fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect,
+} from '../Common';
+
+export default function fileIOFdatasync() {
+ describe('fileIO_fs_fdatasync', async function () {
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDATASYNC_SYNC_0000
+ * @tc.name fileIO_test_fdatasync_sync_000
+ * @tc.desc Test fdatasyncSync() interfaces.
+ * Open the file in read-write mode, and synchronize the file content data.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_fdatasync_sync_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_fdatasync_sync_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ fileIO.fdatasyncSync(file.fd);
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_fdatasync_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDATASYNC_SYNC_0100
+ * @tc.name fileIO_test_fdatasync_sync_001
+ * @tc.desc Test fdatasyncSync() interfaces. Invalid fd parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdatasync_sync_001', 0, async function () {
+
+ try {
+ fileIO.fdatasyncSync(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_fdatasync_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900008 && e.message == 'Bad file descriptor').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDATASYNC_SYNC_0200
+ * @tc.name fileIO_test_fdatasync_sync_002
+ * @tc.desc Test fdatasyncSync() interfaces. Missing parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdatasync_sync_002', 0, async function () {
+
+ try {
+ fileIO.fdatasyncSync();
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_fdatasync_sync_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDATASYNC_ASYNC_0000
+ * @tc.name fileIO_test_fdatasync_async_000
+ * @tc.desc Test fdatasync() interfaces. Callback.
+ * Open the file in read-write mode, and synchronize the file content data.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_fdatasync_async_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_fdatasync_async_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ fileIO.fdatasync(file.fd, (err) => {
+ if (err) {
+ console.log('fileIO_test_fdatasync_async_000 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_fdatasync_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDATASYNC_ASYNC_0100
+ * @tc.name fileIO_test_fdatasync_async_001
+ * @tc.desc Test fdatasync() interfaces. Promise.then().catch().
+ * Open the file in read-write mode, and synchronize the file content data.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdatasync_async_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_fdatasync_async_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ fileIO.fdatasync(file.fd).then(() => {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ }).catch((err) => {
+ console.log('fileIO_test_fdatasync_async_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ console.log('fileIO_test_fdatasync_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDATASYNC_ASYNC_0200
+ * @tc.name fileIO_test_fdatasync_async_002
+ * @tc.desc Test fdatasync() interfaces. await Promise.
+ * Open the file in read-write mode, and synchronize the file content data.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdatasync_async_002', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_fdatasync_async_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ await fileIO.fdatasync(file.fd);
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_fdatasync_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDATASYNC_ASYNC_0300
+ * @tc.name fileIO_test_fdatasync_async_003
+ * @tc.desc Test fdatasync() interfaces. await Promise.
+ * Invalid fd parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdatasync_async_003', 0, async function (done) {
+
+ try {
+ await fileIO.fdatasync(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_fdatasync_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900008 && e.message == 'Bad file descriptor').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDATASYNC_ASYNC_0400
+ * @tc.name fileIO_test_fdatasync_async_004
+ * @tc.desc Test fdatasync() interfaces. Callback.
+ * Invalid fd parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdatasync_async_004', 0, async function (done) {
+
+ try {
+ fileIO.fdatasync(-1, (err) => {
+ if (err) {
+ console.log('fileIO_test_fdatasync_async_004 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900008 && err.message == 'Bad file descriptor').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('fileIO_test_fdatasync_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDATASYNC_ASYNC_0500
+ * @tc.name fileIO_test_fdatasync_async_005
+ * @tc.desc Test fdatasync() interfaces. Promise.then().catch()
+ * Invalid fd parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdatasync_async_005', 0, async function (done) {
+
+ try {
+ fileIO.fdatasync(-1).then(() => {
+ expect(false).assertTrue();
+ }).catch((err) => {
+ console.log('fileIO_test_fdatasync_async_005 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900008 && err.message == 'Bad file descriptor').assertTrue();
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_fdatasync_async_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDATASYNC_ASYNC_0600
+ * @tc.name fileIO_test_fdatasync_async_006
+ * @tc.desc Test fdatasync() interfaces. Promise.
+ * Missing parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdatasync_async_006', 0, async function (done) {
+
+ try {
+ await fileIO.fdatasync();
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_fdatasync_async_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDATASYNC_ASYNC_0700
+ * @tc.name fileIO_test_fdatasync_async_007
+ * @tc.desc Test fdatasync() interfaces. Callback.
+ * Missing parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdatasync_async_007', 0, async function (done) {
+
+ try {
+ fileIO.fdatasync((err) => {
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ console.log('fileIO_test_fdatasync_async_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+})
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/fdopenStream.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/fdopenStream.test.js
similarity index 97%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/fdopenStream.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/fdopenStream.test.js
index a95ec6477bc8e4e4f0d4c2655ec129eff68c61bf..da97a55fac74818d3bbe464eab8c2cb273f60034 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/fdopenStream.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/members/fdopenStream.test.js
@@ -1,947 +1,947 @@
-/*
- * Copyright (C) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the 'License');
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an 'AS IS' BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import {
- fileIO, FILE_CONTENT, prepareFile, nextFileName, isIntNum, describe, it, expect,
-} from '../Common';
-
-export default function fileIOFdOpenStream() {
-describe('fileIO_fs_FdOpenStream', async function () {
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_SYNC_0000
- * @tc.name fileIO_test_fdopenstream_sync_000
- * @tc.desc Test fdopenStreamSync() interface.
- * Create a file stream in 'r' mode and read data from this stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_sync_000', 0, async function () {
- let fpath = await nextFileName('fileIO_test_fdopenstream_sync_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- let fpr = fileIO.fdopenStreamSync(file.fd, 'r');
-
- try {
- expect(fpr !== null).assertTrue();
- expect(fpr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length).assertTrue();
- fpr.writeSync(FILE_CONTENT);
- expect(false).assertTrue();
- } catch (e) {
- fpr.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_fdopenstream_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_SYNC_0010
- * @tc.name fileIO_test_fdopenstream_sync_001
- * @tc.desc Test fdopenStreamSync() interface.
- * Invalid file descriptor.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_sync_001', 0, async function () {
-
- try {
- fileIO.fdopenStreamSync(-1, 'r');
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_fdopenstream_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_SYNC_0200
- * @tc.name fileIO_test_fdopenstream_sync_002
- * @tc.desc Test fdopenStreamSync() interface.
- * Create a file stream in 'r+' mode, reading and writing data from this stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_fdopenstream_sync_002', 0, async function () {
- let fpath = await nextFileName('fileIO_test_fdopenstream_sync_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- let fpr = fileIO.fdopenStreamSync(file.fd, 'r+');
- expect(fpr !== null).assertTrue();
- expect(fpr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length).assertTrue();
- expect(fpr.writeSync(FILE_CONTENT, { offset: 0 }) == FILE_CONTENT.length).assertTrue();
- fpr.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_fdopenstream_sync_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_SYNC_0300
- * @tc.name fileIO_test_fdopenstream_sync_003
- * @tc.desc Test fdopenStreamSync() interface.
- * Invalid file descriptor.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_sync_003', 0, async function () {
-
- try {
- fileIO.fdopenStreamSync(-1, 'r+');
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_fdopenstream_sync_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_SYNC_0400
- * @tc.name fileIO_test_fdopenstream_sync_004
- * @tc.desc Test fdopenStreamSync() interface.
- * Invalid mode.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_sync_004', 0, async function () {
- let fpath = await nextFileName('fileIO_test_fdopenstream_sync_004');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.fdopenStreamSync(file.fd, 'ohos');
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_fdopenstream_sync_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_SYNC_0500
- * @tc.name fileIO_test_fdopenstream_sync_005
- * @tc.desc Test fdopenStreamSync() interface.
- * Missing parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_sync_005', 0, async function () {
- let fpath = await nextFileName('fileIO_test_fdopenstream_sync_005');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.fdopenStreamSync(file.fd);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_fdopenstream_sync_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_SYNC_0600
- * @tc.name fileIO_test_fdopenstream_sync_006
- * @tc.desc Test fdopenStreamSync() interface.
- * Create a file stream in 'w' mode, writing data to file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_sync_006', 0, async function () {
- let fpath = await nextFileName('fileIO_test_fdopenstream_sync_006');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- let fpw = fileIO.fdopenStreamSync(file.fd, 'w');
-
- try {
- expect(fpw !== null).assertTrue();
- expect(fpw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- fpw.readSync(new ArrayBuffer(4096));
- expect(false).assertTrue();
- } catch (e) {
- fpw.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_fdopenstream_sync_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_SYNC_0700
- * @tc.name fileIO_test_fdopenstream_sync_007
- * @tc.desc Test fdopenStreamSync() interface.
- * Create a file stream in 'w' mode and empty contents.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_sync_007', 0, async function () {
- let fpath = await nextFileName('fileIO_test_fdopenstream_sync_007');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file1 = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- expect(isIntNum(file1.fd)).assertTrue();
- let fpw = fileIO.fdopenStreamSync(file1.fd, 'w');
- expect(fpw !== null).assertTrue();
- expect(fpw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- fpw.closeSync();
-
- let file2 = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- let fpr = fileIO.fdopenStreamSync(file2.fd, 'r');
- expect(fpr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length).assertTrue();
- fpr.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_fdopenstream_sync_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_SYNC_0800
- * @tc.name fileIO_test_fdopenstream_sync_008
- * @tc.desc Test fdopenStreamSync() interface.
- * Create a file stream in 'w+' mode and empty contents.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_sync_008', 0, async function () {
- let fpath = await nextFileName('fileIO_test_fdopenstream_sync_008');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- let fpw = fileIO.fdopenStreamSync(file.fd, 'w+');
- expect(fpw !== null).assertTrue();
- expect(fpw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- expect(fpw.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length).assertTrue();
- fpw.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_fdopenstream_sync_008 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_SYNC_0900
- * @tc.name fileIO_test_fdopenstream_sync_009
- * @tc.desc Test fdopenStreamSync() interface.
- * Create a file stream in 'a' mode and append contents.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_sync_009', 0, async function () {
- let fpath = await nextFileName('fileIO_test_fdopenstream_sync_009');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file1 = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file1.fd)).assertTrue();
- let fpa = fileIO.fdopenStreamSync(file1.fd, 'a');
- expect(fpa !== null).assertTrue();
- expect(fpa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- fpa.closeSync();
-
- let file2 = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- let fpr = fileIO.fdopenStreamSync(file2.fd, 'r');
- expect(fpr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length * 2).assertTrue();
- fpr.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_fdopenstream_sync_009 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_SYNC_0100
- * @tc.name fileIO_test_fdopenstream_sync_010
- * @tc.desc Test fdopenStreamSync() interface.
- * Create a file stream in 'a' mode and write data to file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_sync_010', 0, async function () {
- let fpath = await nextFileName('fileIO_test_fdopenstream_sync_010');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- let fpa = fileIO.fdopenStreamSync(file.fd, 'a');
-
- try {
- expect(fpa !== null).assertTrue();
- expect(fpa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- fpa.readSync(new ArrayBuffer(4096));
- expect(false).assertTrue();
- } catch (e) {
- fpa.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_fdopenstream_sync_010 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_SYNC_0110
- * @tc.name fileIO_test_fdopenstream_sync_011
- * @tc.desc Test fdopenStreamSync() interface.
- * Create a file stream in 'a+' mode and append contents.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_sync_011', 0, async function () {
- let fpath = await nextFileName('fileIO_test_fdopenstream_sync_011');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- let fpa = fileIO.fdopenStreamSync(file.fd, 'a+');
- expect(fpa !== null).assertTrue();
- expect(fpa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- expect(fpa.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length * 2).assertTrue();
- fpa.closeSync();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_fdopenstream_sync_011 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_0000
- * @tc.name fileIO_test_fdopenstream_async_000
- * @tc.desc Test fdopenStream() interface. Promise.
- * Create a file stream in 'r' mode and read data from stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_async_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_fdopenstream_async_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- let fpr = await fileIO.fdopenStream(file.fd, 'r');
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- expect(fpr !== null).assertTrue();
- expect(fpr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length).assertTrue();
- fpr.writeSync(FILE_CONTENT);
- expect(false).assertTrue();
- } catch (e) {
- fpr.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_fdopenstream_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_0100
- * @tc.name fileIO_test_fdopenstream_async_001
- * @tc.desc Test fdopenStream() interface. Callback.
- * Create a file stream in 'r' mode and read data from stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_async_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_fdopenstream_async_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.fdopenStream(file.fd, 'r', (err, fpr) => {
- if (err) {
- console.log('fileIO_test_fdopenstream_async_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(fpr !== null).assertTrue();
- expect(fpr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length).assertTrue();
- fpr.write(FILE_CONTENT, (err) => {
- if (err) {
- fpr.closeSync();
- fileIO.unlinkSync(fpath);
- console.log(
- 'fileIO_test_fdopenstream_async_001 error: {message: ' + err.message + ', code: ' + err.code + '}'
- );
- expect(err.code == 13900005 && err.message == 'I/O error').assertTrue();
- done();
- } else {
- expect(false).assertTrue();
- }
- });
- });
- } catch (e) {
- console.log('fileIO_test_fdopenstream_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_0200
- * @tc.name fileIO_test_fdopenstream_async_002
- * @tc.desc Test fdopenStream() interface.
- * Invalid file descriptor.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_async_002', 0, async function (done) {
-
- try {
- await fileIO.fdopenStream(-1, 'r');
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_fdopenstream_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_0300
- * @tc.name fileIO_test_fdopenstream_async_003
- * @tc.desc Test fdopenStream() interface.
- * Invalid file descriptor.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_async_003', 0, async function (done) {
-
- try {
- fileIO.fdopenStream(-1, 'r', (err) => {
- expect(false).assertTrue();
- });
- } catch (e) {
- console.log('fileIO_test_fdopenstream_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_0400
- * @tc.name fileIO_test_fdopenstream_async_004
- * @tc.desc Test fdopenStream() interface. Promise.
- * Create a file stream in 'r+' mode, reading and writing data from this stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 1
- * @tc.require
- */
- it('fileIO_test_fdopenstream_async_004', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_fdopenstream_async_004');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- let fpr = await fileIO.fdopenStream(file.fd, 'r+');
- expect(fpr !== null).assertTrue();
- expect(fpr.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- expect(fpr.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length).assertTrue();
- fpr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_fdopenstream_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_0500
- * @tc.name fileIO_test_fdopenstream_async_005
- * @tc.desc Test fdopenStream() interface. Callback.
- * Create a file stream in 'r+' mode, reading and writing data from this stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 1
- * @tc.require
- */
- it('fileIO_test_fdopenstream_async_005', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_fdopenstream_async_005');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.fdopenStream(file.fd, 'r+', (err, fpr) => {
- if (err) {
- console.log('fileIO_test_fdopenstream_async_005 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(fpr !== null).assertTrue();
- expect(fpr.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- expect(fpr.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length).assertTrue();
- fpr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_fdopenstream_async_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_0600
- * @tc.name fileIO_test_fdopenstream_async_006
- * @tc.desc Test fdopenStream() interface. Promise.
- * Invalid mode.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_async_006', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_fdopenstream_async_006');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- await fileIO.fdopenStream(file.fd, 'ohos');
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_fdopenstream_async_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_0700
- * @tc.name fileIO_test_fdopenstream_async_007
- * @tc.desc Test fdopenStream() interface. Promise.
- * Missing parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_async_007', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_fdopenstream_async_007');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- await fileIO.fdopenStream(file.fd);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_fdopenstream_async_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_0800
- * @tc.name fileIO_test_fdopenstream_async_008
- * @tc.desc Test fdopenStream() interface. Promise.
- * Create a file stream in 'w' mode, can't to read data from this stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_async_008', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_fdopenstream_async_008');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- let fpw = await fileIO.fdopenStream(file.fd, 'w');
-
- try {
- expect(fpw !== null).assertTrue();
- expect(fpw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- fpw.readSync(new ArrayBuffer(4096));
- expect(false).assertTrue();
- } catch (e) {
- fpw.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_fdopenstream_async_008 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_0900
- * @tc.name fileIO_test_fdopenstream_async_009
- * @tc.desc Test fdopenStream() interface. Callback.
- * Create a file stream in 'w' mode, can't to read data from this stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_async_009', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_fdopenstream_async_009');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.fdopenStream(file.fd, 'w', (err, fpw) => {
- if (err) {
- console.log('fileIO_test_fdopenstream_async_009 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(fpw !== null).assertTrue();
- expect(fpw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- fpw.read(new ArrayBuffer(4096), (err) => {
- if (err) {
- fpw.closeSync();
- fileIO.unlinkSync(fpath);
- console.log(
- 'fileIO_test_fdopenstream_async_009 error: {message: ' + err.message + ', code: ' + err.code + '}'
- );
- expect(err.code == 13900005 && err.message == 'I/O error').assertTrue();
- done();
- } else {
- expect(false).assertTrue();
- }
- });
- });
- } catch (e) {
- console.log('fileIO_test_fdopenstream_async_009 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_1000
- * @tc.name fileIO_test_fdopenstream_async_010
- * @tc.desc Test fdopenStream() interface. Promise.
- * Create a file stream in 'w' mode and write data to file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_async_010', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_fdopenstream_async_010');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file1 = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- let fpw = await fileIO.fdopenStream(file1.fd, 'w');
- expect(fpw !== null).assertTrue();
- expect(fpw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- fpw.closeSync();
-
- let file2 = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- let fpr = await fileIO.fdopenStream(file2.fd, 'r');
- expect(fpr.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length).assertTrue();
- fpr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_fdopenstream_async_010 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_1100
- * @tc.name fileIO_test_fdopenstream_async_011
- * @tc.desc Test fdopenStream() interface. Promise.
- * Create a file stream in 'w+' mode and write/read data from this stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_async_011', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_fdopenstream_async_011');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- let fpw = await fileIO.fdopenStream(file.fd, 'w+');
- expect(fpw !== null).assertTrue();
- expect(fpw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- expect(fpw.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length).assertTrue();
- fpw.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_fdopenstream_async_011 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_1200
- * @tc.name fileIO_test_fdopenstream_async_012
- * @tc.desc Test fdopenStream() interface. Callback.
- * Create a file stream in 'w+' mode and write/read data from this stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_async_012', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_fdopenstream_async_012');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.fdopenStream(file.fd, 'w+', (err, fpw) => {
- if (err) {
- console.log('fileIO_test_fdopenstream_async_012 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(fpw !== null).assertTrue();
- expect(fpw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- expect(fpw.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length).assertTrue();
- fpw.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_fdopenstream_async_012 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_1300
- * @tc.name fileIO_test_fdopenstream_async_013
- * @tc.desc Test fdopenStream() interface. Promise.
- * Create a file stream in 'a' mode and append content to file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_async_013', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_fdopenstream_async_013');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file1 = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- let fpa = await fileIO.fdopenStream(file1.fd, 'a');
- expect(fpa !== null).assertTrue();
- expect(fpa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- fpa.closeSync();
-
- let file2 = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- let fpr = await fileIO.fdopenStream(file2.fd, 'r');
- expect(fpr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length * 2).assertTrue();
- fpr.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_fdopenstream_async_013 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_1400
- * @tc.name fileIO_test_fdopenstream_async_014
- * @tc.desc Test fdopenStream() interface. Promise.
- * Create a file stream in 'a' mode and can't to read data from stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_async_014', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_fdopenstream_async_014');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- let fpa = await fileIO.fdopenStream(file.fd, 'a');
-
- try {
- expect(fpa !== null).assertTrue();
- expect(fpa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- fpa.readSync(new ArrayBuffer(4096));
- expect(false).assertTrue();
- } catch (e) {
- fpa.closeSync();
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_fdopenstream_async_014 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_1500
- * @tc.name fileIO_test_fdopenstream_async_015
- * @tc.desc Test fdopenStream() interface. Callback.
- * Create a file stream in 'a' mode and can't to read data from stream.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_async_015', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_fdopenstream_async_015');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
-
- try {
- fileIO.fdopenStream(file.fd, 'a', (err, fpa) => {
- if (err) {
- console.log('fileIO_test_fdopenstream_async_015 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(fpa !== null).assertTrue();
- expect(fpa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- fpa.read(new ArrayBuffer(4096), (err) => {
- if (err) {
- fpa.closeSync();
- fileIO.unlinkSync(fpath);
- console.log(
- 'fileIO_test_fdopenstream_async_015 error: {message: ' + err.message + ', code: ' + err.code + '}'
- );
- expect(err.code == 13900005 && err.message == 'I/O error').assertTrue();
- done();
- } else {
- expect(false).assertTrue();
- }
- });
- });
- } catch (e) {
- console.log('fileIO_test_fdopenstream_async_015 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_1600
- * @tc.name fileIO_test_fdopenstream_async_016
- * @tc.desc Test fdopenStream() interface. Promise.
- * Create a file stream in 'a+' mode and append content to file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_async_016', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_fdopenstream_async_016');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- let fpa = await fileIO.fdopenStream(file.fd, 'a+');
- expect(fpa !== null).assertTrue();
- expect(fpa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- expect(fpa.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length * 2).assertTrue();
- fpa.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_fdopenstream_async_016 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_1700
- * @tc.name fileIO_test_fdopenstream_async_017
- * @tc.desc Test fdopenStream() interface. Callback.
- * Create a file stream in 'a+' mode and append content to file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fdopenstream_async_017', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_fdopenstream_async_017');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.fdopenStream(file.fd, 'a+', (err, fpa) => {
- if (err) {
- console.log('fileIO_test_fdopenstream_async_017 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(fpa !== null).assertTrue();
- expect(fpa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- expect(fpa.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length * 2).assertTrue();
- fpa.closeSync();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_fdopenstream_async_017 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-});
-}
+/*
+ * Copyright (C) 2023 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import {
+ fileIO, FILE_CONTENT, prepareFile, nextFileName, isIntNum, describe, it, expect,
+} from '../Common';
+
+export default function fileIOFdOpenStream() {
+describe('fileIO_fs_FdOpenStream', async function () {
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_SYNC_0000
+ * @tc.name fileIO_test_fdopenstream_sync_000
+ * @tc.desc Test fdopenStreamSync() interface.
+ * Create a file stream in 'r' mode and read data from this stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_sync_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_fdopenstream_sync_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ let fpr = fileIO.fdopenStreamSync(file.fd, 'r');
+
+ try {
+ expect(fpr !== null).assertTrue();
+ expect(fpr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length).assertTrue();
+ fpr.writeSync(FILE_CONTENT);
+ expect(false).assertTrue();
+ } catch (e) {
+ fpr.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_fdopenstream_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_SYNC_0010
+ * @tc.name fileIO_test_fdopenstream_sync_001
+ * @tc.desc Test fdopenStreamSync() interface.
+ * Invalid file descriptor.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_sync_001', 0, async function () {
+
+ try {
+ fileIO.fdopenStreamSync(-1, 'r');
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_fdopenstream_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_SYNC_0200
+ * @tc.name fileIO_test_fdopenstream_sync_002
+ * @tc.desc Test fdopenStreamSync() interface.
+ * Create a file stream in 'r+' mode, reading and writing data from this stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_sync_002', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_fdopenstream_sync_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ let fpr = fileIO.fdopenStreamSync(file.fd, 'r+');
+ expect(fpr !== null).assertTrue();
+ expect(fpr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length).assertTrue();
+ expect(fpr.writeSync(FILE_CONTENT, { offset: 0 }) == FILE_CONTENT.length).assertTrue();
+ fpr.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_fdopenstream_sync_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_SYNC_0300
+ * @tc.name fileIO_test_fdopenstream_sync_003
+ * @tc.desc Test fdopenStreamSync() interface.
+ * Invalid file descriptor.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_sync_003', 0, async function () {
+
+ try {
+ fileIO.fdopenStreamSync(-1, 'r+');
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_fdopenstream_sync_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_SYNC_0400
+ * @tc.name fileIO_test_fdopenstream_sync_004
+ * @tc.desc Test fdopenStreamSync() interface.
+ * Invalid mode.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_sync_004', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_fdopenstream_sync_004');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.fdopenStreamSync(file.fd, 'ohos');
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_fdopenstream_sync_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_SYNC_0500
+ * @tc.name fileIO_test_fdopenstream_sync_005
+ * @tc.desc Test fdopenStreamSync() interface.
+ * Missing parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_sync_005', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_fdopenstream_sync_005');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.fdopenStreamSync(file.fd);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_fdopenstream_sync_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_SYNC_0600
+ * @tc.name fileIO_test_fdopenstream_sync_006
+ * @tc.desc Test fdopenStreamSync() interface.
+ * Create a file stream in 'w' mode, writing data to file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_sync_006', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_fdopenstream_sync_006');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ let fpw = fileIO.fdopenStreamSync(file.fd, 'w');
+
+ try {
+ expect(fpw !== null).assertTrue();
+ expect(fpw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ fpw.readSync(new ArrayBuffer(4096));
+ expect(false).assertTrue();
+ } catch (e) {
+ fpw.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_fdopenstream_sync_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_SYNC_0700
+ * @tc.name fileIO_test_fdopenstream_sync_007
+ * @tc.desc Test fdopenStreamSync() interface.
+ * Create a file stream in 'w' mode and empty contents.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_sync_007', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_fdopenstream_sync_007');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file1 = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ expect(isIntNum(file1.fd)).assertTrue();
+ let fpw = fileIO.fdopenStreamSync(file1.fd, 'w');
+ expect(fpw !== null).assertTrue();
+ expect(fpw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ fpw.closeSync();
+
+ let file2 = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ let fpr = fileIO.fdopenStreamSync(file2.fd, 'r');
+ expect(fpr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length).assertTrue();
+ fpr.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_fdopenstream_sync_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_SYNC_0800
+ * @tc.name fileIO_test_fdopenstream_sync_008
+ * @tc.desc Test fdopenStreamSync() interface.
+ * Create a file stream in 'w+' mode and empty contents.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_sync_008', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_fdopenstream_sync_008');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ let fpw = fileIO.fdopenStreamSync(file.fd, 'w+');
+ expect(fpw !== null).assertTrue();
+ expect(fpw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ expect(fpw.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length).assertTrue();
+ fpw.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_fdopenstream_sync_008 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_SYNC_0900
+ * @tc.name fileIO_test_fdopenstream_sync_009
+ * @tc.desc Test fdopenStreamSync() interface.
+ * Create a file stream in 'a' mode and append contents.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_sync_009', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_fdopenstream_sync_009');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file1 = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file1.fd)).assertTrue();
+ let fpa = fileIO.fdopenStreamSync(file1.fd, 'a');
+ expect(fpa !== null).assertTrue();
+ expect(fpa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ fpa.closeSync();
+
+ let file2 = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ let fpr = fileIO.fdopenStreamSync(file2.fd, 'r');
+ expect(fpr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length * 2).assertTrue();
+ fpr.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_fdopenstream_sync_009 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_SYNC_0100
+ * @tc.name fileIO_test_fdopenstream_sync_010
+ * @tc.desc Test fdopenStreamSync() interface.
+ * Create a file stream in 'a' mode and write data to file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_sync_010', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_fdopenstream_sync_010');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ let fpa = fileIO.fdopenStreamSync(file.fd, 'a');
+
+ try {
+ expect(fpa !== null).assertTrue();
+ expect(fpa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ fpa.readSync(new ArrayBuffer(4096));
+ expect(false).assertTrue();
+ } catch (e) {
+ fpa.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_fdopenstream_sync_010 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_SYNC_0110
+ * @tc.name fileIO_test_fdopenstream_sync_011
+ * @tc.desc Test fdopenStreamSync() interface.
+ * Create a file stream in 'a+' mode and append contents.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_sync_011', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_fdopenstream_sync_011');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ let fpa = fileIO.fdopenStreamSync(file.fd, 'a+');
+ expect(fpa !== null).assertTrue();
+ expect(fpa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ expect(fpa.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length * 2).assertTrue();
+ fpa.closeSync();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_fdopenstream_sync_011 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_0000
+ * @tc.name fileIO_test_fdopenstream_async_000
+ * @tc.desc Test fdopenStream() interface. Promise.
+ * Create a file stream in 'r' mode and read data from stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_async_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_fdopenstream_async_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ let fpr = await fileIO.fdopenStream(file.fd, 'r');
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ expect(fpr !== null).assertTrue();
+ expect(fpr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length).assertTrue();
+ fpr.writeSync(FILE_CONTENT);
+ expect(false).assertTrue();
+ } catch (e) {
+ fpr.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_fdopenstream_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_0100
+ * @tc.name fileIO_test_fdopenstream_async_001
+ * @tc.desc Test fdopenStream() interface. Callback.
+ * Create a file stream in 'r' mode and read data from stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_async_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_fdopenstream_async_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.fdopenStream(file.fd, 'r', (err, fpr) => {
+ if (err) {
+ console.log('fileIO_test_fdopenstream_async_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(fpr !== null).assertTrue();
+ expect(fpr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length).assertTrue();
+ fpr.write(FILE_CONTENT, (err) => {
+ if (err) {
+ fpr.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log(
+ 'fileIO_test_fdopenstream_async_001 error: {message: ' + err.message + ', code: ' + err.code + '}'
+ );
+ expect(err.code == 13900005 && err.message == 'I/O error').assertTrue();
+ done();
+ } else {
+ expect(false).assertTrue();
+ }
+ });
+ });
+ } catch (e) {
+ console.log('fileIO_test_fdopenstream_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_0200
+ * @tc.name fileIO_test_fdopenstream_async_002
+ * @tc.desc Test fdopenStream() interface.
+ * Invalid file descriptor.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_async_002', 0, async function (done) {
+
+ try {
+ await fileIO.fdopenStream(-1, 'r');
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_fdopenstream_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_0300
+ * @tc.name fileIO_test_fdopenstream_async_003
+ * @tc.desc Test fdopenStream() interface.
+ * Invalid file descriptor.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_async_003', 0, async function (done) {
+
+ try {
+ fileIO.fdopenStream(-1, 'r', (err) => {
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ console.log('fileIO_test_fdopenstream_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_0400
+ * @tc.name fileIO_test_fdopenstream_async_004
+ * @tc.desc Test fdopenStream() interface. Promise.
+ * Create a file stream in 'r+' mode, reading and writing data from this stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 1
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_async_004', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_fdopenstream_async_004');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ let fpr = await fileIO.fdopenStream(file.fd, 'r+');
+ expect(fpr !== null).assertTrue();
+ expect(fpr.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ expect(fpr.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length).assertTrue();
+ fpr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_fdopenstream_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_0500
+ * @tc.name fileIO_test_fdopenstream_async_005
+ * @tc.desc Test fdopenStream() interface. Callback.
+ * Create a file stream in 'r+' mode, reading and writing data from this stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 1
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_async_005', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_fdopenstream_async_005');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.fdopenStream(file.fd, 'r+', (err, fpr) => {
+ if (err) {
+ console.log('fileIO_test_fdopenstream_async_005 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(fpr !== null).assertTrue();
+ expect(fpr.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ expect(fpr.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length).assertTrue();
+ fpr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_fdopenstream_async_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_0600
+ * @tc.name fileIO_test_fdopenstream_async_006
+ * @tc.desc Test fdopenStream() interface. Promise.
+ * Invalid mode.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_async_006', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_fdopenstream_async_006');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ await fileIO.fdopenStream(file.fd, 'ohos');
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_fdopenstream_async_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_0700
+ * @tc.name fileIO_test_fdopenstream_async_007
+ * @tc.desc Test fdopenStream() interface. Promise.
+ * Missing parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_async_007', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_fdopenstream_async_007');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ await fileIO.fdopenStream(file.fd);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_fdopenstream_async_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_0800
+ * @tc.name fileIO_test_fdopenstream_async_008
+ * @tc.desc Test fdopenStream() interface. Promise.
+ * Create a file stream in 'w' mode, can't to read data from this stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_async_008', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_fdopenstream_async_008');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ let fpw = await fileIO.fdopenStream(file.fd, 'w');
+
+ try {
+ expect(fpw !== null).assertTrue();
+ expect(fpw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ fpw.readSync(new ArrayBuffer(4096));
+ expect(false).assertTrue();
+ } catch (e) {
+ fpw.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_fdopenstream_async_008 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_0900
+ * @tc.name fileIO_test_fdopenstream_async_009
+ * @tc.desc Test fdopenStream() interface. Callback.
+ * Create a file stream in 'w' mode, can't to read data from this stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_async_009', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_fdopenstream_async_009');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.fdopenStream(file.fd, 'w', (err, fpw) => {
+ if (err) {
+ console.log('fileIO_test_fdopenstream_async_009 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(fpw !== null).assertTrue();
+ expect(fpw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ fpw.read(new ArrayBuffer(4096), (err) => {
+ if (err) {
+ fpw.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log(
+ 'fileIO_test_fdopenstream_async_009 error: {message: ' + err.message + ', code: ' + err.code + '}'
+ );
+ expect(err.code == 13900005 && err.message == 'I/O error').assertTrue();
+ done();
+ } else {
+ expect(false).assertTrue();
+ }
+ });
+ });
+ } catch (e) {
+ console.log('fileIO_test_fdopenstream_async_009 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_1000
+ * @tc.name fileIO_test_fdopenstream_async_010
+ * @tc.desc Test fdopenStream() interface. Promise.
+ * Create a file stream in 'w' mode and write data to file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_async_010', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_fdopenstream_async_010');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file1 = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ let fpw = await fileIO.fdopenStream(file1.fd, 'w');
+ expect(fpw !== null).assertTrue();
+ expect(fpw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ fpw.closeSync();
+
+ let file2 = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ let fpr = await fileIO.fdopenStream(file2.fd, 'r');
+ expect(fpr.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length).assertTrue();
+ fpr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_fdopenstream_async_010 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_1100
+ * @tc.name fileIO_test_fdopenstream_async_011
+ * @tc.desc Test fdopenStream() interface. Promise.
+ * Create a file stream in 'w+' mode and write/read data from this stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_async_011', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_fdopenstream_async_011');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ let fpw = await fileIO.fdopenStream(file.fd, 'w+');
+ expect(fpw !== null).assertTrue();
+ expect(fpw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ expect(fpw.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length).assertTrue();
+ fpw.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_fdopenstream_async_011 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_1200
+ * @tc.name fileIO_test_fdopenstream_async_012
+ * @tc.desc Test fdopenStream() interface. Callback.
+ * Create a file stream in 'w+' mode and write/read data from this stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_async_012', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_fdopenstream_async_012');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.fdopenStream(file.fd, 'w+', (err, fpw) => {
+ if (err) {
+ console.log('fileIO_test_fdopenstream_async_012 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(fpw !== null).assertTrue();
+ expect(fpw.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ expect(fpw.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length).assertTrue();
+ fpw.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_fdopenstream_async_012 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_1300
+ * @tc.name fileIO_test_fdopenstream_async_013
+ * @tc.desc Test fdopenStream() interface. Promise.
+ * Create a file stream in 'a' mode and append content to file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_async_013', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_fdopenstream_async_013');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file1 = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ let fpa = await fileIO.fdopenStream(file1.fd, 'a');
+ expect(fpa !== null).assertTrue();
+ expect(fpa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ fpa.closeSync();
+
+ let file2 = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ let fpr = await fileIO.fdopenStream(file2.fd, 'r');
+ expect(fpr.readSync(new ArrayBuffer(4096)) == FILE_CONTENT.length * 2).assertTrue();
+ fpr.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_fdopenstream_async_013 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_1400
+ * @tc.name fileIO_test_fdopenstream_async_014
+ * @tc.desc Test fdopenStream() interface. Promise.
+ * Create a file stream in 'a' mode and can't to read data from stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_async_014', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_fdopenstream_async_014');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ let fpa = await fileIO.fdopenStream(file.fd, 'a');
+
+ try {
+ expect(fpa !== null).assertTrue();
+ expect(fpa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ fpa.readSync(new ArrayBuffer(4096));
+ expect(false).assertTrue();
+ } catch (e) {
+ fpa.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_fdopenstream_async_014 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900005 && e.message == 'I/O error').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_1500
+ * @tc.name fileIO_test_fdopenstream_async_015
+ * @tc.desc Test fdopenStream() interface. Callback.
+ * Create a file stream in 'a' mode and can't to read data from stream.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_async_015', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_fdopenstream_async_015');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+
+ try {
+ fileIO.fdopenStream(file.fd, 'a', (err, fpa) => {
+ if (err) {
+ console.log('fileIO_test_fdopenstream_async_015 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(fpa !== null).assertTrue();
+ expect(fpa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ fpa.read(new ArrayBuffer(4096), (err) => {
+ if (err) {
+ fpa.closeSync();
+ fileIO.unlinkSync(fpath);
+ console.log(
+ 'fileIO_test_fdopenstream_async_015 error: {message: ' + err.message + ', code: ' + err.code + '}'
+ );
+ expect(err.code == 13900005 && err.message == 'I/O error').assertTrue();
+ done();
+ } else {
+ expect(false).assertTrue();
+ }
+ });
+ });
+ } catch (e) {
+ console.log('fileIO_test_fdopenstream_async_015 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_1600
+ * @tc.name fileIO_test_fdopenstream_async_016
+ * @tc.desc Test fdopenStream() interface. Promise.
+ * Create a file stream in 'a+' mode and append content to file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_async_016', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_fdopenstream_async_016');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ let fpa = await fileIO.fdopenStream(file.fd, 'a+');
+ expect(fpa !== null).assertTrue();
+ expect(fpa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ expect(fpa.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length * 2).assertTrue();
+ fpa.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_fdopenstream_async_016 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FDOPENSTREAM_ASYNC_1700
+ * @tc.name fileIO_test_fdopenstream_async_017
+ * @tc.desc Test fdopenStream() interface. Callback.
+ * Create a file stream in 'a+' mode and append content to file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fdopenstream_async_017', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_fdopenstream_async_017');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.fdopenStream(file.fd, 'a+', (err, fpa) => {
+ if (err) {
+ console.log('fileIO_test_fdopenstream_async_017 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(fpa !== null).assertTrue();
+ expect(fpa.writeSync(FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ expect(fpa.readSync(new ArrayBuffer(4096), { offset: 0 }) == FILE_CONTENT.length * 2).assertTrue();
+ fpa.closeSync();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_fdopenstream_async_017 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+});
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/fileLock.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/fileLock.test.js
similarity index 97%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/fileLock.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/fileLock.test.js
index dae867d2cfefdfd4fd557fd828d313d879fb78b1..a8763e2dcdfcbf3b99498532f61393cf1d622385 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/fileLock.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/members/fileLock.test.js
@@ -1,737 +1,737 @@
-/*
- * Copyright (C) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the 'License');
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an 'AS IS' BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import {
- fileIO, FILE_CONTENT, prepareFile, nextFileName, isIntNum, describe, it, expect,
-} from '../Common';
-
-export default function fileIOFileLock() {
- describe('fileIO_fs_file_lock', function () {
-
- /**
- * @tc.number FILE_TEST_FILELOCK_PROMISE_0000
- * @tc.name fileIO_test_filelock_promise_000
- * @tc.desc Test lock() interfaces. argument is : default.
- * Open the file, file lock() and unlock()
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_filelock_promise_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_filelock_promise_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- await file.lock();
- file.unlock();
- expect(true).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_filelock_promise_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number FILE_TEST_FILELOCK_PROMISE_0100
- * @tc.name fileIO_test_filelock_promise_001
- * @tc.desc Test lock() interfaces. argument is : true.
- * Open the file, file lock(true) and unlock()
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_filelock_promise_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_filelock_promise_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- await file.lock(true);
- file.unlock();
- expect(true).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_filelock_promise_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number FILE_TEST_FILELOCK_PROMISE_0200
- * @tc.name fileIO_test_filelock_promise_002
- * @tc.desc Test lock() interfaces. argument is : false.
- * Open the file, file lock(false) and unlock()
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_filelock_promise_002', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_filelock_promise_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- await file.lock(false);
- file.unlock();
- expect(true).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_filelock_promise_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number FILE_TEST_FILELOCK_PROMISE_0300
- * @tc.name fileIO_test_filelock_promise_003
- * @tc.desc Test tryLock() interfaces. argument is : default.
- * Open the file, file lock() ,tryLock() and unlock()
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_filelock_promise_003', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_filelock_promise_003');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- await file.lock();
- file.tryLock();
- file.unlock();
- expect(true).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_filelock_promise_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number FILE_TEST_FILELOCK_PROMISE_0400
- * @tc.name fileIO_test_filelock_promise_004
- * @tc.desc Test tryLock() interfaces. argument is : true.
- * Open the file, file lock() ,tryLock(true) and unlock()
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_filelock_promise_004', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_filelock_promise_004');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- await file.lock();
- file.tryLock(true);
- file.unlock();
- expect(true).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_filelock_promise_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number FILE_TEST_FILELOCK_PROMISE_0500
- * @tc.name fileIO_test_filelock_promise_005
- * @tc.desc Test tryLock() interfaces. argument is : false.
- * Open the file, file lock() ,tryLock(false) and unlock()
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_filelock_promise_005', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_filelock_promise_005');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- await file.lock();
- file.tryLock(false);
- file.unlock();
- expect(true).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_filelock_promise_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number FILE_TEST_FILELOCK_PROMISE_0600
- * @tc.name fileIO_test_filelock_promise_006
- * @tc.desc Open the file, no file lock(), tryLock(), unlock(),
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_filelock_promise_006', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_filelock_promise_006');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- file.tryLock();
- file.unlock();
- expect(true).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_filelock_promise_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number FILE_TEST_FILELOCK_PROMISE_0700
- * @tc.name fileIO_test_filelock_promise_007
- * @tc.desc Open the file, no file lock(), no tryLock(), unlock(),
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_filelock_promise_007', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_filelock_promise_007');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- file.unlock();
- expect(true).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_filelock_promise_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number FILE_TEST_FILELOCK_PROMISE_0800
- * @tc.name fileIO_test_filelock_promise_008
- * @tc.desc Test lock() interfaces.
- * Open the file, file.lock(), use default mode = false.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_filelock_promise_008', 3, async function (done) {
- let fpath = await nextFileName('fileIO_test_filelock_promise_008');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- await file.lock(undefined);
- file.unlock();
- expect(true).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_filelock_promise_008 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number FILE_TEST_FILELOCK_PROMISE_0900
- * @tc.name fileIO_test_filelock_promise_009
- * @tc.desc File.trylock(), use default mode = false.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_filelock_promise_009', 3, async function (done) {
- let fpath = await nextFileName('fileIO_test_filelock_promise_009');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- await file.lock();
- file.tryLock(undefined);
- file.unlock();
- expect(true).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_filelock_promise_009 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number FILE_TEST_FILELOCK_PROMISE_ABNORMAL_0000
- * @tc.name fileIO_test_filelock_promise_abnormal_000
- * @tc.desc Test lock() interfaces. argument is : null.
- * Open the file, file lock(null).
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_filelock_promise_abnormal_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_filelock_promise_abnormal_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- await file.lock(null);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_filelock_promise_abnormal_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number FILE_TEST_FILELOCK_PROMISE_ABNORMAL_0100
- * @tc.name fileIO_test_filelock_promise_abnormal_001
- * @tc.desc Test lock() interfaces. argument is : true, true.
- * Open the file, file lock(true, true).
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_filelock_promise_abnormal_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_filelock_promise_abnormal_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- await file.lock(true, true);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_filelock_promise_abnormal_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number FILE_TEST_FILELOCK_PROMISE_ABNORMAL_0200
- * @tc.name fileIO_test_filelock_promise_abnormal_002
- * @tc.desc Test lock() interfaces. argument is : -1.
- * Open the file, file lock(-1).
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_filelock_promise_abnormal_002', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_filelock_promise_abnormal_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- await file.lock(-1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_filelock_promise_abnormal_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number FILE_TEST_FILELOCK_PROMISE_ABNORMAL_0300
- * @tc.name fileIO_test_filelock_promise_abnormal_003
- * @tc.desc Test tryLock() interfaces. argument is : null.
- * Open the file, file lock(), tryLock(null).
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_filelock_promise_abnormal_003', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_filelock_promise_abnormal_003');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- await file.lock();
- file.tryLock(null);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_filelock_promise_abnormal_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number FILE_TEST_FILELOCK_PROMISE_ABNORMAL_0400
- * @tc.name fileIO_test_filelock_promise_abnormal_004
- * @tc.desc Test tryLock() interfaces. argument is : true, true.
- * Open the file, file lock(), tryLock(true, true).
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_filelock_promise_abnormal_004', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_filelock_promise_abnormal_004');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- await file.lock();
- file.tryLock(true, true);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_filelock_promise_abnormal_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number FILE_TEST_FILELOCK_PROMISE_ABNORMAL_0500
- * @tc.name fileIO_test_filelock_promise_abnormal_005
- * @tc.desc Test tryLock() interfaces. argument is : -1.
- * Open the file, file lock(), tryLock(-1).
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_filelock_promise_abnormal_005', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_filelock_promise_abnormal_005');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- await file.lock();
- file.tryLock(-1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_filelock_promise_abnormal_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number FILE_TEST_FILELOCK_PROMISE_ABNORMAL_0600
- * @tc.name fileIO_test_filelock_promise_abnormal_006
- * @tc.desc Test unlock() interfaces. argument is : true.
- * Open the file, file lock(), tryLock(), unlock(true),
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_filelock_promise_abnormal_006', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_filelock_promise_abnormal_006');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- await file.lock();
- file.tryLock();
- file.unlock(true);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_filelock_promise_abnormal_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number FILE_TEST_FILELOCK_CALLBACK_0000
- * @tc.name fileIO_test_filelock_callback_000
- * @tc.desc Test lock() interfaces. argument is : default.
- * Open the file, file lock() and unlock()
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_filelock_callback_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_filelock_callback_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- file.lock((err) => {
- if (err) {
- console.log('fileIO_test_filelock_callback_000 err ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- file.unlock();
- expect(true).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_filelock_callback_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number FILE_TEST_FILELOCK_CALLBACK_0100
- * @tc.name fileIO_test_filelock_callback_001
- * @tc.desc Test lock() interfaces. argument is : true.
- * Open the file, file lock(true) and unlock()
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_filelock_callback_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_filelock_callback_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- file.lock(true, (err) => {
- if (err) {
- console.log('fileIO_test_filelock_callback_001 err ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- file.unlock();
- expect(true).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_filelock_callback_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number FILE_TEST_FILELOCK_CALLBACK_0200
- * @tc.name fileIO_test_filelock_callback_002
- * @tc.desc Test lock() interfaces. argument is : false.
- * Open the file, file lock(false) and unlock()
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_filelock_callback_002', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_filelock_callback_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- file.lock(false, (err) => {
- if (err) {
- console.log('fileIO_test_filelock_callback_002 err ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- file.unlock();
- expect(true).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_filelock_callback_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number FILE_TEST_FILELOCK_CALLBACK_0300
- * @tc.name fileIO_test_filelock_callback_003
- * @tc.desc Test lock() interfaces.
- * Open the file, file.lock(), use default mode = false.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_filelock_callback_003', 3, async function (done) {
- let fpath = await nextFileName('fileIO_test_filelock_callback_003');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- file.lock(undefined, (err) => {
- if (err) {
- console.log('fileIO_test_filelock_callback_003 err ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- file.unlock();
- expect(true).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_filelock_callback_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number FILE_TEST_FILELOCK_CALLBACK_ABNORMAL_0000
- * @tc.name fileIO_test_filelock_callback_abnormal_000
- * @tc.desc Test lock() interfaces. argument is : null.
- * Open the file, file lock(null).
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_filelock_callback_abnormal_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_filelock_callback_abnormal_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- file.lock(null, (err) => {
- expect(false).assertTrue();
- });
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_filelock_callback_abnormal_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number FILE_TEST_FILELOCK_CALLBACK_ABNORMAL_0100
- * @tc.name fileIO_test_filelock_callback_abnormal_001
- * @tc.desc Test lock() interfaces. argument is : true, true.
- * Open the file, file lock(true, true).
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_filelock_callback_abnormal_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_filelock_callback_abnormal_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- file.lock(true, true, (err) => {
- expect(false).assertTrue();
- });
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_filelock_callback_abnormal_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number FILE_TEST_FILELOCK_CALLBACK_ABNORMAL_0200
- * @tc.name fileIO_test_filelock_callback_abnormal_002
- * @tc.desc Test lock() interfaces. argument is : -1.
- * Open the file, file lock(-1).
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_filelock_callback_abnormal_002', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_filelock_callback_abnormal_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- file.lock(-1, (err) => {
- expect(false).assertTrue();
- });
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_filelock_callback_abnormal_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-});
+/*
+ * Copyright (C) 2023 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import {
+ fileIO, FILE_CONTENT, prepareFile, nextFileName, isIntNum, describe, it, expect,
+} from '../Common';
+
+export default function fileIOFileLock() {
+ describe('fileIO_fs_file_lock', function () {
+
+ /**
+ * @tc.number FILE_TEST_FILELOCK_PROMISE_0000
+ * @tc.name fileIO_test_filelock_promise_000
+ * @tc.desc Test lock() interfaces. argument is : default.
+ * Open the file, file lock() and unlock()
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_filelock_promise_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_filelock_promise_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ await file.lock();
+ file.unlock();
+ expect(true).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_filelock_promise_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number FILE_TEST_FILELOCK_PROMISE_0100
+ * @tc.name fileIO_test_filelock_promise_001
+ * @tc.desc Test lock() interfaces. argument is : true.
+ * Open the file, file lock(true) and unlock()
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_filelock_promise_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_filelock_promise_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ await file.lock(true);
+ file.unlock();
+ expect(true).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_filelock_promise_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number FILE_TEST_FILELOCK_PROMISE_0200
+ * @tc.name fileIO_test_filelock_promise_002
+ * @tc.desc Test lock() interfaces. argument is : false.
+ * Open the file, file lock(false) and unlock()
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_filelock_promise_002', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_filelock_promise_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ await file.lock(false);
+ file.unlock();
+ expect(true).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_filelock_promise_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number FILE_TEST_FILELOCK_PROMISE_0300
+ * @tc.name fileIO_test_filelock_promise_003
+ * @tc.desc Test tryLock() interfaces. argument is : default.
+ * Open the file, file lock() ,tryLock() and unlock()
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_filelock_promise_003', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_filelock_promise_003');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ await file.lock();
+ file.tryLock();
+ file.unlock();
+ expect(true).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_filelock_promise_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number FILE_TEST_FILELOCK_PROMISE_0400
+ * @tc.name fileIO_test_filelock_promise_004
+ * @tc.desc Test tryLock() interfaces. argument is : true.
+ * Open the file, file lock() ,tryLock(true) and unlock()
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_filelock_promise_004', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_filelock_promise_004');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ await file.lock();
+ file.tryLock(true);
+ file.unlock();
+ expect(true).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_filelock_promise_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number FILE_TEST_FILELOCK_PROMISE_0500
+ * @tc.name fileIO_test_filelock_promise_005
+ * @tc.desc Test tryLock() interfaces. argument is : false.
+ * Open the file, file lock() ,tryLock(false) and unlock()
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_filelock_promise_005', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_filelock_promise_005');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ await file.lock();
+ file.tryLock(false);
+ file.unlock();
+ expect(true).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_filelock_promise_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number FILE_TEST_FILELOCK_PROMISE_0600
+ * @tc.name fileIO_test_filelock_promise_006
+ * @tc.desc Open the file, no file lock(), tryLock(), unlock(),
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_filelock_promise_006', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_filelock_promise_006');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ file.tryLock();
+ file.unlock();
+ expect(true).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_filelock_promise_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number FILE_TEST_FILELOCK_PROMISE_0700
+ * @tc.name fileIO_test_filelock_promise_007
+ * @tc.desc Open the file, no file lock(), no tryLock(), unlock(),
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_filelock_promise_007', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_filelock_promise_007');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ file.unlock();
+ expect(true).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_filelock_promise_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number FILE_TEST_FILELOCK_PROMISE_0800
+ * @tc.name fileIO_test_filelock_promise_008
+ * @tc.desc Test lock() interfaces.
+ * Open the file, file.lock(), use default mode = false.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_filelock_promise_008', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_test_filelock_promise_008');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ await file.lock(undefined);
+ file.unlock();
+ expect(true).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_filelock_promise_008 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number FILE_TEST_FILELOCK_PROMISE_0900
+ * @tc.name fileIO_test_filelock_promise_009
+ * @tc.desc File.trylock(), use default mode = false.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_filelock_promise_009', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_test_filelock_promise_009');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ await file.lock();
+ file.tryLock(undefined);
+ file.unlock();
+ expect(true).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_filelock_promise_009 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number FILE_TEST_FILELOCK_PROMISE_ABNORMAL_0000
+ * @tc.name fileIO_test_filelock_promise_abnormal_000
+ * @tc.desc Test lock() interfaces. argument is : null.
+ * Open the file, file lock(null).
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_filelock_promise_abnormal_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_filelock_promise_abnormal_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ await file.lock(null);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_filelock_promise_abnormal_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number FILE_TEST_FILELOCK_PROMISE_ABNORMAL_0100
+ * @tc.name fileIO_test_filelock_promise_abnormal_001
+ * @tc.desc Test lock() interfaces. argument is : true, true.
+ * Open the file, file lock(true, true).
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_filelock_promise_abnormal_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_filelock_promise_abnormal_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ await file.lock(true, true);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_filelock_promise_abnormal_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number FILE_TEST_FILELOCK_PROMISE_ABNORMAL_0200
+ * @tc.name fileIO_test_filelock_promise_abnormal_002
+ * @tc.desc Test lock() interfaces. argument is : -1.
+ * Open the file, file lock(-1).
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_filelock_promise_abnormal_002', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_filelock_promise_abnormal_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ await file.lock(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_filelock_promise_abnormal_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number FILE_TEST_FILELOCK_PROMISE_ABNORMAL_0300
+ * @tc.name fileIO_test_filelock_promise_abnormal_003
+ * @tc.desc Test tryLock() interfaces. argument is : null.
+ * Open the file, file lock(), tryLock(null).
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_filelock_promise_abnormal_003', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_filelock_promise_abnormal_003');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ await file.lock();
+ file.tryLock(null);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_filelock_promise_abnormal_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number FILE_TEST_FILELOCK_PROMISE_ABNORMAL_0400
+ * @tc.name fileIO_test_filelock_promise_abnormal_004
+ * @tc.desc Test tryLock() interfaces. argument is : true, true.
+ * Open the file, file lock(), tryLock(true, true).
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_filelock_promise_abnormal_004', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_filelock_promise_abnormal_004');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ await file.lock();
+ file.tryLock(true, true);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_filelock_promise_abnormal_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number FILE_TEST_FILELOCK_PROMISE_ABNORMAL_0500
+ * @tc.name fileIO_test_filelock_promise_abnormal_005
+ * @tc.desc Test tryLock() interfaces. argument is : -1.
+ * Open the file, file lock(), tryLock(-1).
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_filelock_promise_abnormal_005', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_filelock_promise_abnormal_005');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ await file.lock();
+ file.tryLock(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_filelock_promise_abnormal_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number FILE_TEST_FILELOCK_PROMISE_ABNORMAL_0600
+ * @tc.name fileIO_test_filelock_promise_abnormal_006
+ * @tc.desc Test unlock() interfaces. argument is : true.
+ * Open the file, file lock(), tryLock(), unlock(true),
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_filelock_promise_abnormal_006', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_filelock_promise_abnormal_006');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ await file.lock();
+ file.tryLock();
+ file.unlock(true);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_filelock_promise_abnormal_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number FILE_TEST_FILELOCK_CALLBACK_0000
+ * @tc.name fileIO_test_filelock_callback_000
+ * @tc.desc Test lock() interfaces. argument is : default.
+ * Open the file, file lock() and unlock()
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_filelock_callback_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_filelock_callback_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ file.lock((err) => {
+ if (err) {
+ console.log('fileIO_test_filelock_callback_000 err ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ file.unlock();
+ expect(true).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_filelock_callback_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number FILE_TEST_FILELOCK_CALLBACK_0100
+ * @tc.name fileIO_test_filelock_callback_001
+ * @tc.desc Test lock() interfaces. argument is : true.
+ * Open the file, file lock(true) and unlock()
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_filelock_callback_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_filelock_callback_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ file.lock(true, (err) => {
+ if (err) {
+ console.log('fileIO_test_filelock_callback_001 err ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ file.unlock();
+ expect(true).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_filelock_callback_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number FILE_TEST_FILELOCK_CALLBACK_0200
+ * @tc.name fileIO_test_filelock_callback_002
+ * @tc.desc Test lock() interfaces. argument is : false.
+ * Open the file, file lock(false) and unlock()
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_filelock_callback_002', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_filelock_callback_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ file.lock(false, (err) => {
+ if (err) {
+ console.log('fileIO_test_filelock_callback_002 err ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ file.unlock();
+ expect(true).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_filelock_callback_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number FILE_TEST_FILELOCK_CALLBACK_0300
+ * @tc.name fileIO_test_filelock_callback_003
+ * @tc.desc Test lock() interfaces.
+ * Open the file, file.lock(), use default mode = false.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_filelock_callback_003', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_test_filelock_callback_003');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ file.lock(undefined, (err) => {
+ if (err) {
+ console.log('fileIO_test_filelock_callback_003 err ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ file.unlock();
+ expect(true).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_filelock_callback_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number FILE_TEST_FILELOCK_CALLBACK_ABNORMAL_0000
+ * @tc.name fileIO_test_filelock_callback_abnormal_000
+ * @tc.desc Test lock() interfaces. argument is : null.
+ * Open the file, file lock(null).
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_filelock_callback_abnormal_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_filelock_callback_abnormal_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ file.lock(null, (err) => {
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_filelock_callback_abnormal_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number FILE_TEST_FILELOCK_CALLBACK_ABNORMAL_0100
+ * @tc.name fileIO_test_filelock_callback_abnormal_001
+ * @tc.desc Test lock() interfaces. argument is : true, true.
+ * Open the file, file lock(true, true).
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_filelock_callback_abnormal_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_filelock_callback_abnormal_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ file.lock(true, true, (err) => {
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_filelock_callback_abnormal_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number FILE_TEST_FILELOCK_CALLBACK_ABNORMAL_0200
+ * @tc.name fileIO_test_filelock_callback_abnormal_002
+ * @tc.desc Test lock() interfaces. argument is : -1.
+ * Open the file, file lock(-1).
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_filelock_callback_abnormal_002', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_filelock_callback_abnormal_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ file.lock(-1, (err) => {
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_filelock_callback_abnormal_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+});
}
\ No newline at end of file
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/filerw.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/filerw.test.js
similarity index 100%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/filerw.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/filerw.test.js
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/fsync.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/fsync.test.js
similarity index 96%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/fsync.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/fsync.test.js
index 95d829bf41890303791cdc7a6d11ea717638239f..b5c8fdec86ec2acf8eff7e41fd77896ff2ca64df 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/fsync.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/members/fsync.test.js
@@ -1,294 +1,294 @@
-/*
- * Copyright (C) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the 'License');
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an 'AS IS' BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import {
- fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect,
-} from '../Common';
-
-export default function fileIOFsync() {
-describe('fileIO_fs_fsync', function () {
-
- /**
- * @tc.number SUB_DF_FILEIO_FSYNC_SYNC_0000
- * @tc.name fileIO_test_fsync_sync_000
- * @tc.desc Test fsyncSync() interface.
- * Open the file in read-write mode, and synchronize the file content data.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_fsync_sync_000', 0, async function () {
- let fpath = await nextFileName('fileIO_test_fsync_sync_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- fileIO.fsyncSync(file.fd);
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_fsync_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FSYNC_SYNC_0100
- * @tc.name fileIO_test_fsync_sync_001
- * @tc.desc Test fsyncSync() interface. Invalid fd parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fsync_sync_001', 0, function () {
-
- try {
- fileIO.fsyncSync(-1);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_fsync_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900008 && e.message == 'Bad file descriptor').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FSYNC_SYNC_0200
- * @tc.name fileIO_test_fsync_sync_002
- * @tc.desc Test fsyncSync() interface. Missing parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fsync_sync_002', 0, function () {
-
- try {
- fileIO.fsyncSync();
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_fsync_sync_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FSYNC_ASYNC_0000
- * @tc.name fileIO_test_fsync_async_000
- * @tc.desc Test fsync() interface. await Promise.
- * Open the file in read-write mode, and synchronize the file content data.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_fsync_async_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_fsync_async_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- await fileIO.fsync(file.fd);
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_fsync_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FSYNC_ASYNC_0100
- * @tc.name fileIO_test_fsync_async_001
- * @tc.desc Test fsync() interface. Promise.then().catch()
- * Open the file in read-write mode, and synchronize the file content data.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fsync_async_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_fsync_async_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- fileIO.fsync(file.fd).then(() => {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- }).catch((err) => {
- console.log('fileIO_test_fsync_async_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- });
- } catch (e) {
- console.log('fileIO_test_fsync_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FSYNC_ASYNC_0200
- * @tc.name fileIO_test_fsync_async_002
- * @tc.desc Test fsync() interface. Callback.
- * Open the file in read-write mode, and synchronize the file content data.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fsync_async_002', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_fsync_sync_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- fileIO.fsync(file.fd, (err) => {
- if (err) {
- console.log('fileIO_test_fsync_async_002 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- });
- done();
- } catch (e) {
- console.log('fileIO_test_fsync_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FSYNC_ASYNC_0300
- * @tc.name fileIO_test_fsync_async_003
- * @tc.desc Test fsync() interface. await Promise.
- * Invalid fd parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fsync_async_003', 0, async function (done) {
-
- try {
- await fileIO.fsync(-1);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_fsync_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900008 && e.message == 'Bad file descriptor').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FSYNC_ASYNC_0400
- * @tc.name fileIO_test_fsync_async_004
- * @tc.desc Test fsync() interface. Callback.
- * Invalid fd parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fsync_async_004', 0, async function (done) {
-
- try {
- fileIO.fsync(-1, (err) => {
- if (err) {
- console.log('fileIO_test_fsync_async_004 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900008 && err.message == 'Bad file descriptor').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('fileIO_test_fsync_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FSYNC_ASYNC_0500
- * @tc.name fileIO_test_fsync_async_005
- * @tc.desc Test fsync() interface. Promise.then().catch()
- * Missing parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fsync_async_005', 0, async function (done) {
-
- try {
- fileIO.fsync(-1).then(() => {
- expect(false).assertTrue();
- }).catch((err) => {
- console.log('fileIO_test_fsync_async_005 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900008 && err.message == 'Bad file descriptor').assertTrue();
- done();
- });
- } catch (e) {
- console.log('fileIO_test_fsync_async_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FSYNC_ASYNC_0600
- * @tc.name fileIO_test_fsync_async_006
- * @tc.desc Test fsync() interface. await Promise.
- * Missing parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fsync_async_006', 0, async function (done) {
-
- try {
- await fileIO.fsync();
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_fsync_async_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_FSYNC_ASYNC_0700
- * @tc.name fileIO_test_fsync_async_007
- * @tc.desc Test fsync() interface. Callback.
- * Missing parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_fsync_async_007', 0, async function (done) {
-
- try {
- fileIO.fsync((err) => {
- expect(false).assertTrue();
- });
- } catch (e) {
- console.log('fileIO_test_fsync_async_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-})
-}
+/*
+ * Copyright (C) 2023 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import {
+ fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect,
+} from '../Common';
+
+export default function fileIOFsync() {
+describe('fileIO_fs_fsync', function () {
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FSYNC_SYNC_0000
+ * @tc.name fileIO_test_fsync_sync_000
+ * @tc.desc Test fsyncSync() interface.
+ * Open the file in read-write mode, and synchronize the file content data.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_fsync_sync_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_fsync_sync_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ fileIO.fsyncSync(file.fd);
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_fsync_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FSYNC_SYNC_0100
+ * @tc.name fileIO_test_fsync_sync_001
+ * @tc.desc Test fsyncSync() interface. Invalid fd parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fsync_sync_001', 0, function () {
+
+ try {
+ fileIO.fsyncSync(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_fsync_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900008 && e.message == 'Bad file descriptor').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FSYNC_SYNC_0200
+ * @tc.name fileIO_test_fsync_sync_002
+ * @tc.desc Test fsyncSync() interface. Missing parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fsync_sync_002', 0, function () {
+
+ try {
+ fileIO.fsyncSync();
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_fsync_sync_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FSYNC_ASYNC_0000
+ * @tc.name fileIO_test_fsync_async_000
+ * @tc.desc Test fsync() interface. await Promise.
+ * Open the file in read-write mode, and synchronize the file content data.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_fsync_async_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_fsync_async_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ await fileIO.fsync(file.fd);
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_fsync_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FSYNC_ASYNC_0100
+ * @tc.name fileIO_test_fsync_async_001
+ * @tc.desc Test fsync() interface. Promise.then().catch()
+ * Open the file in read-write mode, and synchronize the file content data.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fsync_async_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_fsync_async_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ fileIO.fsync(file.fd).then(() => {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ }).catch((err) => {
+ console.log('fileIO_test_fsync_async_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ console.log('fileIO_test_fsync_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FSYNC_ASYNC_0200
+ * @tc.name fileIO_test_fsync_async_002
+ * @tc.desc Test fsync() interface. Callback.
+ * Open the file in read-write mode, and synchronize the file content data.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fsync_async_002', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_fsync_sync_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ fileIO.fsync(file.fd, (err) => {
+ if (err) {
+ console.log('fileIO_test_fsync_async_002 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ });
+ done();
+ } catch (e) {
+ console.log('fileIO_test_fsync_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FSYNC_ASYNC_0300
+ * @tc.name fileIO_test_fsync_async_003
+ * @tc.desc Test fsync() interface. await Promise.
+ * Invalid fd parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fsync_async_003', 0, async function (done) {
+
+ try {
+ await fileIO.fsync(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_fsync_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900008 && e.message == 'Bad file descriptor').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FSYNC_ASYNC_0400
+ * @tc.name fileIO_test_fsync_async_004
+ * @tc.desc Test fsync() interface. Callback.
+ * Invalid fd parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fsync_async_004', 0, async function (done) {
+
+ try {
+ fileIO.fsync(-1, (err) => {
+ if (err) {
+ console.log('fileIO_test_fsync_async_004 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900008 && err.message == 'Bad file descriptor').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('fileIO_test_fsync_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FSYNC_ASYNC_0500
+ * @tc.name fileIO_test_fsync_async_005
+ * @tc.desc Test fsync() interface. Promise.then().catch()
+ * Missing parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fsync_async_005', 0, async function (done) {
+
+ try {
+ fileIO.fsync(-1).then(() => {
+ expect(false).assertTrue();
+ }).catch((err) => {
+ console.log('fileIO_test_fsync_async_005 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900008 && err.message == 'Bad file descriptor').assertTrue();
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_fsync_async_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FSYNC_ASYNC_0600
+ * @tc.name fileIO_test_fsync_async_006
+ * @tc.desc Test fsync() interface. await Promise.
+ * Missing parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fsync_async_006', 0, async function (done) {
+
+ try {
+ await fileIO.fsync();
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_fsync_async_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_FSYNC_ASYNC_0700
+ * @tc.name fileIO_test_fsync_async_007
+ * @tc.desc Test fsync() interface. Callback.
+ * Missing parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_fsync_async_007', 0, async function (done) {
+
+ try {
+ fileIO.fsync((err) => {
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ console.log('fileIO_test_fsync_async_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+})
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/hash.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/hash.test.js
similarity index 97%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/hash.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/hash.test.js
index 4abe15933c84dd53559fc27526d97fe79dcef31b..99215f89e7dda4487e95a2f25c1db50e2f694177 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/hash.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/members/hash.test.js
@@ -1,246 +1,246 @@
-/*
- * Copyright (C) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the 'License');
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an 'AS IS' BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import fileHash from '@ohos.file.hash';
-import {
- fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect,
-} from '../Common';
-
-export default function fileIOHash() {
-describe('fileIO_fs_hash', function () {
-
- /**
- * @tc.number SUB_DF_FILEIO_HASH_ASYNC_0000
- * @tc.name fileIO_test_hash_async_000
- * @tc.desc Test hash() interface. Promise.
- * Encrypt files using the MD5 hashing algorithm
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_hash_async_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_hash_async_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let str = await fileHash.hash(fpath,'md5');
- console.log('fileIO_test_hash_async_000 hash value is ' + str);
- expect(str == '5EB63BBBE01EEED093CB22BB8F5ACDC3').assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_hash_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_HASH_ASYNC_0100
- * @tc.name fileIO_test_hash_async_001
- * @tc.desc Test hash() interface. Callback.
- * Encrypt files using the MD5 hashing algorithm.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_hash_async_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_hash_async_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileHash.hash(fpath, 'md5', (err, str) => {
- if (err) {
- console.log('fileIO_test_hash_async_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- console.log('fileIO_test_hash_async_001 hash value is ' + str);
- expect(str == '5EB63BBBE01EEED093CB22BB8F5ACDC3').assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_hash_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_HASH_ASYNC_0200
- * @tc.name fileIO_test_hash_async_002
- * @tc.desc Test hash() interface. Promise.
- * Encrypt files using the sha1 hashing algorithm.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_hash_async_002', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_hash_async_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let str = await fileHash.hash(fpath, 'sha1');
- console.log('fileIO_test_hash_async_000 hash value is ' + str);
- expect(str == '2AAE6C35C94FCFB415DBE95F408B9CE91EE846ED').assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_hash_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_HASH_ASYNC_0300
- * @tc.name fileIO_test_hash_async_003
- * @tc.desc Test hash() interface. Callback.
- * Encrypt files using the sha1 hashing algorithm.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_hash_async_003', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_hash_async_003');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileHash.hash(fpath, 'sha1', (err, str) => {
- if (err) {
- console.log('fileIO_test_hash_async_003 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- console.log('fileIO_test_hash_async_003 hash value is ' + str);
- expect(str == '2AAE6C35C94FCFB415DBE95F408B9CE91EE846ED').assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_hash_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_HASH_ASYNC_0400
- * @tc.name fileIO_test_hash_async_004
- * @tc.desc Test hash() interface. Promise.
- * Encrypt files using the sha256 hashing algorithm.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_hash_async_004', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_hash_async_004');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let str = await fileHash.hash(fpath, 'sha256');
- console.log('fileIO_test_hash_async_001 hash value is ' + str);
- expect(str == 'B94D27B9934D3E08A52E52D7DA7DABFAC484EFE37A5380EE9088F7ACE2EFCDE9').assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_hash_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_HASH_ASYNC_0500
- * @tc.name fileIO_test_hash_async_005
- * @tc.desc Test hash() interface. Callback.
- * Encrypt files using the sha256 hashing algorithm.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_hash_async_005', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_hash_async_005');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileHash.hash(fpath, 'sha256', (err, str) => {
- if (err) {
- console.log('fileIO_test_hash_async_005 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- console.log('fileIO_test_hash_async_005 hash value is ' + str);
- expect(str == 'B94D27B9934D3E08A52E52D7DA7DABFAC484EFE37A5380EE9088F7ACE2EFCDE9').assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_hash_async_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_HASH_ASYNC_0600
- * @tc.name fileIO_test_hash_async_006
- * @tc.desc Test hash() interface. Promise.
- * Invalid mode.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_hash_async_006', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_hash_async_006');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- await fileHash.hash(fpath, '256');
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_hash_async_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_HASH_ASYNC_0700
- * @tc.name fileIO_test_hash_async_007
- * @tc.desc Test hash() interface. Promise.
- * Missing parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_hash_async_007', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_hash_async_007');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileHash.hash(fpath, (err) => {
- expect(false).assertTrue();
- });
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_hash_async_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-})
-}
+/*
+ * Copyright (C) 2023 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import fileHash from '@ohos.file.hash';
+import {
+ fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect,
+} from '../Common';
+
+export default function fileIOHash() {
+describe('fileIO_fs_hash', function () {
+
+ /**
+ * @tc.number SUB_DF_FILEIO_HASH_ASYNC_0000
+ * @tc.name fileIO_test_hash_async_000
+ * @tc.desc Test hash() interface. Promise.
+ * Encrypt files using the MD5 hashing algorithm
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_hash_async_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_hash_async_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let str = await fileHash.hash(fpath,'md5');
+ console.log('fileIO_test_hash_async_000 hash value is ' + str);
+ expect(str == '5EB63BBBE01EEED093CB22BB8F5ACDC3').assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_hash_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_HASH_ASYNC_0100
+ * @tc.name fileIO_test_hash_async_001
+ * @tc.desc Test hash() interface. Callback.
+ * Encrypt files using the MD5 hashing algorithm.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_hash_async_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_hash_async_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileHash.hash(fpath, 'md5', (err, str) => {
+ if (err) {
+ console.log('fileIO_test_hash_async_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ console.log('fileIO_test_hash_async_001 hash value is ' + str);
+ expect(str == '5EB63BBBE01EEED093CB22BB8F5ACDC3').assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_hash_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_HASH_ASYNC_0200
+ * @tc.name fileIO_test_hash_async_002
+ * @tc.desc Test hash() interface. Promise.
+ * Encrypt files using the sha1 hashing algorithm.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_hash_async_002', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_hash_async_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let str = await fileHash.hash(fpath, 'sha1');
+ console.log('fileIO_test_hash_async_000 hash value is ' + str);
+ expect(str == '2AAE6C35C94FCFB415DBE95F408B9CE91EE846ED').assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_hash_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_HASH_ASYNC_0300
+ * @tc.name fileIO_test_hash_async_003
+ * @tc.desc Test hash() interface. Callback.
+ * Encrypt files using the sha1 hashing algorithm.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_hash_async_003', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_hash_async_003');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileHash.hash(fpath, 'sha1', (err, str) => {
+ if (err) {
+ console.log('fileIO_test_hash_async_003 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ console.log('fileIO_test_hash_async_003 hash value is ' + str);
+ expect(str == '2AAE6C35C94FCFB415DBE95F408B9CE91EE846ED').assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_hash_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_HASH_ASYNC_0400
+ * @tc.name fileIO_test_hash_async_004
+ * @tc.desc Test hash() interface. Promise.
+ * Encrypt files using the sha256 hashing algorithm.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_hash_async_004', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_hash_async_004');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let str = await fileHash.hash(fpath, 'sha256');
+ console.log('fileIO_test_hash_async_001 hash value is ' + str);
+ expect(str == 'B94D27B9934D3E08A52E52D7DA7DABFAC484EFE37A5380EE9088F7ACE2EFCDE9').assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_hash_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_HASH_ASYNC_0500
+ * @tc.name fileIO_test_hash_async_005
+ * @tc.desc Test hash() interface. Callback.
+ * Encrypt files using the sha256 hashing algorithm.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_hash_async_005', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_hash_async_005');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileHash.hash(fpath, 'sha256', (err, str) => {
+ if (err) {
+ console.log('fileIO_test_hash_async_005 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ console.log('fileIO_test_hash_async_005 hash value is ' + str);
+ expect(str == 'B94D27B9934D3E08A52E52D7DA7DABFAC484EFE37A5380EE9088F7ACE2EFCDE9').assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_hash_async_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_HASH_ASYNC_0600
+ * @tc.name fileIO_test_hash_async_006
+ * @tc.desc Test hash() interface. Promise.
+ * Invalid mode.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_hash_async_006', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_hash_async_006');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ await fileHash.hash(fpath, '256');
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_hash_async_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_HASH_ASYNC_0700
+ * @tc.name fileIO_test_hash_async_007
+ * @tc.desc Test hash() interface. Promise.
+ * Missing parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_hash_async_007', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_hash_async_007');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileHash.hash(fpath, (err) => {
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_hash_async_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+})
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/listFile.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/listFile.test.js
similarity index 100%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/listFile.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/listFile.test.js
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/lstat.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/lstat.test.js
similarity index 97%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/lstat.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/lstat.test.js
index 017e44b43916fae7c88aba174caa896bccd11cf0..57ecedf7dae617bf6d8f85751505a18ed7c7b7d8 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/lstat.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/members/lstat.test.js
@@ -1,1707 +1,1707 @@
-/*
- * Copyright (C) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the 'License');
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an 'AS IS' BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import {
- fileIO, FILE_CONTENT, prepareFile, nextFileName, isIntNum, isBigInt,
- describe, it, expect,
-} from '../Common';
-
-export default function fileIOLstat() {
-describe('fileIO_fs_lstat', function () {
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_SYNC_0000
- * @tc.name fileIO_lstat_sync_000
- * @tc.desc Test lstatSync() interface.
- * Enter the path parameter to get the file stat.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_lstat_sync_000', 0, async function () {
- let fpath = await nextFileName('fileIO_lstat_sync_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.lstatSync(fpath);
- expect(stat !== null).assertTrue();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_lstat_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_SYNC_0100
- * @tc.name fileIO_lstat_sync_001
- * @tc.desc Test lstatSync() interface.
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_sync_001', 0, async function () {
- let fpath = await nextFileName('fileIO_lstat_sync_001');
-
- try {
- fileIO.lstatSync(fpath);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_lstat_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_SYNC_0200
- * @tc.name fileIO_lstat_sync_002
- * @tc.desc Test lstatSync() interface.
- * Missing parameters.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_sync_002', 0, async function () {
-
- try {
- fileIO.lstatSync();
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_lstat_sync_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_INO_0000
- * @tc.name fileIO_lstat_ino_000
- * @tc.desc Test the ino member of class Stat.
- * Enter the path parameter to get stat.ino of the file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_ino_000', 0, async function () {
- let fpath = await nextFileName('fileIO_lstat_ino_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- try {
- let stat = fileIO.lstatSync(fpath);
- expect(isBigInt(stat.ino)).assertTrue();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_lstat_ino_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_MODE_0000
- * @tc.name fileIO_lstat_mode_000
- * @tc.desc Test the mode member of class Stat.
- * Enter the path parameter to get stat.mode of the file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_mode_000', 0, async function () {
- let fpath = await nextFileName('fileIO_lstat_mode_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.lstatSync(fpath);
- expect(isIntNum(stat.mode)).assertTrue();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_lstat_mode_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_UID_0000
- * @tc.name fileIO_lstat_uid_000
- * @tc.desc Test the uid member of class Stat.
- * Enter the path parameter to get stat.uid of the file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_uid_000', 0, async function () {
- let fpath = await nextFileName('fileIO_lstat_uid_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.lstatSync(fpath);
- expect(isIntNum(stat.uid)).assertTrue();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_lstat_uid_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_GID_0000
- * @tc.name fileIO_lstat_gid_000
- * @tc.desc Test the gid member of class Stat.
- * Enter the path parameter to get stat.gid of the file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_gid_000', 0, async function () {
- let fpath = await nextFileName('fileIO_lstat_gid_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.lstatSync(fpath);
- expect(isIntNum(stat.gid)).assertTrue();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_lstat_gid_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_SIZE_0000
- * @tc.name fileIO_lstat_size_000
- * @tc.desc Test the size member of class Stat.
- * Enter the path parameter to get stat.size of the file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_size_000', 0, async function () {
- let fpath = await nextFileName('fileIO_lstat_size_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.lstatSync(fpath);
- expect(isIntNum(stat.size)).assertTrue();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_lstat_size_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ATIME_0000
- * @tc.name fileIO_lstat_atime_000
- * @tc.desc Test the atime member of class Stat.
- * Enter the path or parameter to get stat.atime of the file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_atime_000', 0, async function () {
- let fpath = await nextFileName('fileIO_lstat_atime_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.lstatSync(fpath);
- expect(isIntNum(stat.atime)).assertTrue();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_lstat_atime_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_MTIME_0000
- * @tc.name fileIO_lstat_mtime_000
- * @tc.desc Test the mtime member of class Stat.
- * Enter the path parameter to get stat.mtime of the file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_mtime_000', 0, async function () {
- let fpath = await nextFileName('fileIO_lstat_mtime_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.lstatSync(fpath);
- expect(isIntNum(stat.mtime)).assertTrue();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_lstat_mtime_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_CTIME_0000
- * @tc.name fileIO_lstat_ctime_000
- * @tc.desc Test the ctime member of class Stat.
- * Enter the path parameter to get stat.ctime of the file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_ctime_000', 0, async function () {
- let fpath = await nextFileName('fileIO_lstat_ctime_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.lstatSync(fpath);
- expect(isIntNum(stat.ctime)).assertTrue();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_lstat_ctime_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_IS_BLOCK_DEVICE_0000
- * @tc.name fileIO_lstat_is_block_device_000
- * @tc.desc Test Lstat.isBlockDevice() interface.
- * This interface shall not treat a normal file as a block special device.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_is_block_device_000', 0, async function () {
- let fpath = await nextFileName('fileIO_lstat_is_block_device_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.lstatSync(fpath);
- expect(stat.isBlockDevice() === false).assertTrue();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_lstat_is_block_device_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_IS_BLOCK_DEVICE_0100
- * @tc.name fileIO_test_lstat_is_block_device_001
- * @tc.desc Test Lstat.isBlockDevice() interface.
- * This interface does not require parameters.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_lstat_is_block_device_001', 0, async function () {
- let fpath = await nextFileName('fileIO_test_lstat_is_block_device_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.lstatSync(fpath).isBlockDevice(-1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_lstat_is_block_device_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_IS_CHARACTER_DEVICE_0000
- * @tc.name fileIO_lstat_is_character_device_000
- * @tc.desc Test Lstat.isCharacterDevice() interface.
- * This interface shall not treat a normal file as a character special device.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_is_character_device_000', 0, async function () {
- let fpath = await nextFileName('fileIO_lstat_is_character_device_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.lstatSync(fpath);
- expect(stat.isCharacterDevice() === false).assertTrue();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_lstat_is_character_device_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_IS_CHARACTER_DEVICE_0100
- * @tc.name fileIO_lstat_is_character_device_001
- * @tc.desc Test Lstat.isCharacterDevice() interface.
- * This interface does not require parameters.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_lstat_is_character_device_001', 0, async function () {
- let fpath = await nextFileName('fileIO_test_lstat_is_character_device_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.lstatSync(fpath).isCharacterDevice(-1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_lstat_is_character_device_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_IS_DIRECTORY_0000
- * @tc.name fileIO_lstat_is_directory_000
- * @tc.desc Test Lstat.isDirectory() interface.
- * This interface shall not treat a normal file as a directory.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_is_directory_000', 0, async function () {
- let fpath = await nextFileName('fileIO_lstat_is_directory_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.lstatSync(fpath);
- expect(stat.isDirectory() === false).assertTrue();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_lstat_is_directory_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_IS_DIRECTORY_0100
- * @tc.name fileIO_lstat_is_directory_001
- * @tc.desc Test Lstat.isDirectory() interface.
- * This interface shall treat a directory as a directory.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_is_directory_001', 0, async function () {
- let dpath = await nextFileName('fileIO_lstat_is_directory_001') + 'd';
-
- try {
- fileIO.mkdirSync(dpath);
- let stat = fileIO.lstatSync(dpath);
- expect(stat.isDirectory() === true).assertTrue();
- fileIO.rmdirSync(dpath);
- } catch (e) {
- console.log('fileIO_lstat_is_directory_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_IS_DIRECTORY_0200
- * @tc.name fileIO_lstat_is_directory_002
- * @tc.desc Test Lstat.isDirectory() interface.
- * This interface does not require parameters.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_is_directory_002', 0, async function () {
- let dpath = await nextFileName('fileIO_lstat_is_directory_002') + 'd';
-
- try {
- fileIO.mkdirSync(dpath);
- fileIO.lstatSync(dpath).isDirectory(-1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.rmdirSync(dpath);
- console.log('fileIO_lstat_is_directory_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_IS_FIFO_0000
- * @tc.name fileIO_lstat_is_fifo_000
- * @tc.desc Test Lstat.isFIFO() interface.
- * This interface shall not treat a normal file as a FIFO.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_is_fifo_000', 0, async function () {
- let fpath = await nextFileName('fileIO_lstat_is_fifo_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.lstatSync(fpath);
- expect(stat.isFIFO() === false).assertTrue();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_lstat_is_fifo_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_IS_FIFO_0100
- * @tc.name fileIO_lstat_is_fifo_001
- * @tc.desc Test Lstat.isFIFO() interface.
- * This interface does not require parameters.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_lstat_is_fifo_002', 0, async function () {
- let fpath = await nextFileName('fileIO_test_lstat_is_fifo_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.lstatSync(fpath).isFIFO(-1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_lstat_is_fifo_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_IS_FILE_0000
- * @tc.name fileIO_lstat_is_file_000
- * @tc.desc Test Lstat.isFile() interface.
- * This interface shall treat a normal file as a normal file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_is_file_000', 0, async function () {
- let fpath = await nextFileName('fileIO_lstat_is_file_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.lstatSync(fpath);
- expect(stat.isFile() === true).assertTrue();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_lstat_is_file_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_IS_FILE_0100
- * @tc.name fileIO_lstat_is_file_001
- * @tc.desc Test Lstat.isFile() interface.
- * This interface shall not treat a directory as a normal file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_is_file_001', 0, async function () {
- let dpath = await nextFileName('fileIO_lstat_is_file_001');
-
- try {
- fileIO.mkdirSync(dpath);
- let stat = fileIO.lstatSync(dpath);
- expect(stat.isFile() === false).assertTrue();
- fileIO.rmdirSync(dpath);
- } catch (e) {
- console.log('fileIO_lstat_is_file_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_IS_FILE_0200
- * @tc.name fileIO_test_lstat_is_file_002
- * @tc.desc Test Lstat.isFile() interface.
- * This interface does not require parameters.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_lstat_is_file_002', 0, async function () {
- let dpath = await nextFileName('fileIO_test_lstat_is_file_002');
-
- try {
- fileIO.mkdirSync(dpath);
- fileIO.lstatSync(dpath).isFile(-1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.rmdirSync(dpath);
- console.log('fileIO_test_lstat_is_file_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_IS_SOCKET_0000
- * @tc.name fileIO_lstat_is_socket_000
- * @tc.desc Test Lstat.isSocket() interface.
- * This interface shall not treat a file as a socket.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_is_socket_000', 0, async function () {
- let fpath = await nextFileName('fileIO_lstat_is_socket_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.lstatSync(fpath);
- expect(stat.isSocket() === false).assertTrue();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_lstat_is_socket_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_IS_SOCKET_0100
- * @tc.name fileIO_lstat_is_socket_001
- * @tc.desc Test Lstat.isSocket() interface.
- * This interface does not require parameters.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_is_socket_001', 0, async function () {
- let fpath = await nextFileName('fileIO_lstat_is_socket_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.lstatSync(fpath).isSocket(-1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_lstat_is_socket_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_IS_SYMBOLIC_LINK_0000
- * @tc.name fileIO_lstat_is_symbolic_link_000
- * @tc.desc Test Lstat.isSymbolicLink() interface.
- * This interface shall not treat a normal file as a symbolic link.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_is_symbolic_link_000', 0, async function () {
- let fpath = await nextFileName('fileIO_lstat_is_symbolic_link_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.lstatSync(fpath);
- expect(stat.isSymbolicLink() === false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_lstat_is_symbolic_link_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_IS_SYMBOLIC_LINK_0100
- * @tc.name fileIO_lstat_is_symbolic_link_001
- * @tc.desc Test Lstat.isSymbolicLink() interface.
- * This interface does not require parameters.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_is_symbolic_link_001', 0, async function () {
- let fpath = await nextFileName('fileIO_lstat_is_symbolic_link_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.lstatSync(fpath).isSymbolicLink(-1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_lstat_is_symbolic_link_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_0000
- * @tc.name fileIO_lstat_async_000
- * @tc.desc Test lstat() interface. Promise.then().catch()
- * Enter the path parameter to get the file stat.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_lstat_async_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.lstat(fpath).then((stat) => {
- expect(stat !== null).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- }).catch((err) => {
- console.log('fileIO_lstat_async_000 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- });
- } catch (e) {
- console.log('fileIO_lstat_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_0100
- * @tc.name fileIO_lstat_async_001
- * @tc.desc Test lstat() interface. Callback.
- * Enter the path or parameter to get the file stat.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.lstat(fpath, (err) => {
- if(err) {
- console.log('fileIO_lstat_async_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_lstat_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_0200
- * @tc.name fileIO_lstat_async_002
- * @tc.desc Test lstat() interface. Promise.
- * Enter the path or parameter to get the file stat.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_002', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.lstat(fpath);
- expect(stat !== null).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_lstat_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_0300
- * @tc.name fileIO_lstat_async_003
- * @tc.desc Test lstat() interface.
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_003', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_003');
-
- try {
- fileIO.lstat(fpath, (err) => {
- if (err) {
- console.log('fileIO_lstat_async_003 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('fileIO_lstat_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_0400
- * @tc.name fileIO_lstat_async_004
- * @tc.desc Test lstat() interface. Promise.
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_004', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_004');
-
- try {
- await fileIO.lstat(fpath);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_lstat_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_INO_0000
- * @tc.name fileIO_lstat_async_ino_000
- * @tc.desc Test the ino member of class Stat. Promise.
- * Enter the path parameter to get stat.ino of the file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_ino_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_ino_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.lstat(fpath);
- expect(isBigInt(stat.ino)).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_lstat_async_ino_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_INO_0100
- * @tc.name fileIO_lstat_async_ino_001
- * @tc.desc Test the ino member of class Stat. Callback.
- * Enter the path parameter to get stat.ino of the file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_ino_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_ino_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.lstat(fpath, (err, stat) => {
- if(err) {
- console.log('fileIO_lstat_async_ino_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isBigInt(stat.ino)).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_lstat_async_ino_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_MODE_0000
- * @tc.name fileIO_lstat_async_mode_000
- * @tc.desc Test the mode member of class Stat. Promise.
- * Enter the path or parameter to get stat.mode of the file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_mode_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_mode_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.lstat(fpath);
- expect(isIntNum(stat.mode)).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_lstat_async_mode_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_MODE_0100
- * @tc.name fileIO_lstat_async_mode_001
- * @tc.desc Test the mode member of class Stat. Callback.
- * Enter the path or parameter to get stat.mode of the file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_mode_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_mode_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.lstat(fpath, (err, stat) => {
- if(err) {
- console.log('fileIO_lstat_async_mode_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(stat.mode)).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_lstat_async_mode_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_UID_0000
- * @tc.name fileIO_lstat_async_uid_000
- * @tc.desc Test the uid member of class Stat. Promise.
- * Enter the path parameter to get stat.uid of the file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_uid_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_uid_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.lstat(fpath);
- expect(isIntNum(stat.uid)).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_lstat_async_uid_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_UID_0100
- * @tc.name fileIO_lstat_async_uid_001
- * @tc.desc Test the uid member of class Stat. Callback.
- * Enter the path parameter to get stat.uid of the file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_uid_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_uid_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.lstat(fpath, (err, stat) => {
- if(err) {
- console.log('fileIO_lstat_async_uid_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(stat.uid)).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_lstat_async_uid_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_GID_0000
- * @tc.name fileIO_lstat_async_gid_000
- * @tc.desc Test the gid member of class Stat. Promise.
- * Enter the path parameter to get stat.gid of the file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_gid_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_gid_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.lstat(fpath);
- expect(isIntNum(stat.gid)).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_lstat_async_gid_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_GID_0100
- * @tc.name fileIO_lstat_async_gid_001
- * @tc.desc Test the gid member of class Stat. Callback.
- * Enter the path parameter to get stat.gid of the file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_gid_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_gid_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.lstat(fpath, (err, stat) => {
- if (err) {
- console.log('fileIO_lstat_async_gid_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(stat.gid)).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_lstat_async_gid_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_SIZE_0000
- * @tc.name fileIO_lstat_async_size_000
- * @tc.desc Test the size member of class Stat. Promise.
- * Enter the path parameter to get stat.size of the file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_size_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_size_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.lstat(fpath);
- expect(isIntNum(stat.size)).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_lstat_async_size_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_SIZE_0100
- * @tc.name fileIO_lstat_async_size_001
- * @tc.desc Test the size member of class Stat. Callback.
- * Enter the path parameter to get stat.size of the file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_size_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_size_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.lstat(fpath, (err, stat) => {
- if (err) {
- console.log('fileIO_lstat_async_size_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(stat.size)).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_lstat_async_size_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_ATIME_0000
- * @tc.name fileIO_lstat_async_atime_000
- * @tc.desc Test the atime member of class Stat. Promise.
- * Enter the path parameter to get stat.atime of the file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_atime_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_atime_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.lstat(fpath);
- expect(isIntNum(stat.atime)).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_lstat_async_atime_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_ATIME_0100
- * @tc.name fileIO_lstat_async_atime_001
- * @tc.desc Test the atime member of class Stat. Callback.
- * Enter the path or fd parameter to get stat.atime of the file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_atime_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_atime_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.lstat(fpath, (err, stat) => {
- if (err) {
- console.log('fileIO_lstat_async_atime_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(stat.atime)).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_lstat_async_atime_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_MTIME_0000
- * @tc.name fileIO_lstat_async_mtime_000
- * @tc.desc Test the mtime member of class Stat. Promise.
- * Enter the path or fd parameter to get stat.mtime of the file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_mtime_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_mtime_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.lstat(fpath);
- expect(isIntNum(stat.mtime)).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_lstat_async_mtime_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_MTIME_0100
- * @tc.name fileIO_lstat_async_mtime_001
- * @tc.desc Test the mtime member of class Stat. Callback.
- * Enter the path or fd parameter to get stat.mtime of the file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_mtime_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_mtime_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.lstat(fpath, (err, stat) => {
- if (err) {
- console.log('fileIO_lstat_async_mtime_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(stat.mtime)).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_lstat_async_mtime_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_CTIME_0000
- * @tc.name fileIO_lstat_async_ctime_000
- * @tc.desc Test the ctime member of class Stat. Promise.
- * Enter the path or fd parameter to get stat.ctime of the file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_ctime_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_ctime_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.lstat(fpath);
- expect(isIntNum(stat.ctime)).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_lstat_async_ctime_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_CTIME_0100
- * @tc.name fileIO_lstat_async_ctime_001
- * @tc.desc Test the ctime member of class Stat. Callback.
- * Enter the path or fd parameter to get stat.ctime of the file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_ctime_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_ctime_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.lstat(fpath, (err, stat) => {
- if (err) {
- console.log('fileIO_lstat_async_ctime_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(stat.ctime)).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_lstat_async_ctime_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_BLOCK_DEVICE_0000
- * @tc.name fileIO_lstat_async_is_block_device_000
- * @tc.desc Test the isBlockDevice() method of class Stat. Promise.
- * This interface shall not treat a normal file as a block special device.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_is_block_device_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_is_block_device_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.lstat(fpath);
- expect(stat.isBlockDevice() === false).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_lstat_async_is_block_device_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_BLOCK_DEVICE_0010
- * @tc.name fileIO_lstat_async_is_block_device_001
- * @tc.desc Test the isBlockDevice() method of class Stat. Callback.
- * This interface shall not treat a normal file as a block special device.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_is_block_device_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_is_block_device_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.lstat(fpath, (err, stat) => {
- if (err) {
- console.log('fileIO_lstat_async_is_block_device_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(stat.isBlockDevice() === false).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_lstat_async_is_block_device_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_CHARACTER_DEVICE_0000
- * @tc.name fileIO_lstat_async_is_character_device_000
- * @tc.desc Test the isCharacterDevice() method of class Stat. Promise.
- * This interface shall not treat a normal file as a character special device.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_is_character_device_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_is_character_device_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.lstat(fpath);
- expect(stat.isCharacterDevice() === false).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_lstat_async_is_character_device_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_CHARACTER_DEVICE_0010
- * @tc.name fileIO_lstat_async_is_character_device_001
- * @tc.desc Test the isCharacterDevice() method of class Stat. Callback.
- * This interface shall not treat a normal file as a character special device.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_is_character_device_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_is_character_device_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.lstat(fpath, (err, stat) => {
- if (err) {
- console.log('fileIO_lstat_async_is_character_device_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(stat.isCharacterDevice() === false).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_lstat_async_is_character_device_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_DIRECTORY_0000
- * @tc.name fileIO_lstat_async_is_directory_000
- * @tc.desc Test the isDirectory() method of class Stat. Promise.
- * This interface shall not treat a normal file as a directory.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_is_directory_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_is_directory_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.lstat(fpath);
- expect(stat.isDirectory() === false).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_lstat_async_is_directory_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_DIRECTORY_0010
- * @tc.name fileIO_lstat_async_is_directory_001
- * @tc.desc Test the isDirectory() method of class Stat. Promise.
- * This interface shall not treat a directory as a directory.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_is_directory_001', 0, async function (done) {
- let dpath = await nextFileName('fileIO_lstat_async_is_directory_001') + 'd';
-
-
- try {
- fileIO.mkdirSync(dpath);
- let stat = await fileIO.lstat(dpath);
- expect(stat.isDirectory() === true).assertTrue();
- fileIO.rmdirSync(dpath);
- done();
- } catch (e) {
- console.log('fileIO_lstat_async_is_directory_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_DIRECTORY_0020
- * @tc.name fileIO_lstat_async_is_directory_002
- * @tc.desc Test the isDirectory() method of class Stat. Callback.
- * This interface shall not treat a directory as a directory.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_is_directory_002', 0, async function (done) {
- let dpath = await nextFileName('fileIO_lstat_async_is_directory_002') + 'd';
-
- try {
- fileIO.mkdirSync(dpath);
- fileIO.lstat(dpath, (err, stat) => {
- if (err) {
- console.log('fileIO_lstat_async_is_directory_002 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(stat.isDirectory() === true).assertTrue();
- fileIO.rmdirSync(dpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_lstat_async_is_directory_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_FIFO_0000
- * @tc.name fileIO_lstat_async_is_fifo_000
- * @tc.desc Test the isFIFO() method of class Stat. Promise.
- * This interface shall not treat a normal file as a FIFO.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_is_fifo_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_is_fifo_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.lstat(fpath);
- expect(stat.isFIFO() === false).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_lstat_async_is_fifo_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_FIFO_0010
- * @tc.name fileIO_lstat_async_is_fifo_001
- * @tc.desc Test the isFIFO() method of class Stat. Callback.
- * This interface shall not treat a normal file as a FIFO.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_is_fifo_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_is_fifo_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.lstat(fpath, (err, stat) => {
- if (err) {
- console.log('fileIO_lstat_async_is_character_device_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(stat.isFIFO() === false).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_lstat_async_is_fifo_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_FILE_0000
- * @tc.name fileIO_lstat_async_is_file_000
- * @tc.desc Test the isFile() method of class Stat. Promise.
- * This interface shall treat a normal file as a normal file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_is_file_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_is_file_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.lstat(fpath);
- expect(stat.isFile() === true).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_lstat_async_is_file_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_FILE_0010
- * @tc.name fileIO_lstat_async_is_file_001
- * @tc.desc Test the isFile() method of class Stat. Callback.
- * This interface shall treat a normal file as a normal file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_is_file_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_is_file_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.lstat(fpath, (err, stat) => {
- if (err) {
- console.log('fileIO_lstat_async_is_file_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(stat.isFile() === true).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_lstat_async_is_file_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_FILE_0020
- * @tc.name fileIO_lstat_async_is_file_002
- * @tc.desc Test the isFile() method of class Stat. Promise.
- * This interface shall not treat a directory as a normal file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_is_file_002', 0, async function (done) {
- let dpath = await nextFileName('fileIO_lstat_async_is_file_002');
-
- try {
- fileIO.mkdirSync(dpath);
- let stat = await fileIO.lstat(dpath);
- expect(stat.isFile() === false).assertTrue();
- fileIO.rmdirSync(dpath);
- done();
- } catch (e) {
- console.log('fileIO_lstat_async_is_file_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_SOCKET_0000
- * @tc.name fileIO_lstat_async_is_socket_000
- * @tc.desc Test the isSocket() method of class Stat. Promise.
- * This interface shall not treat a file as a socket.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_is_socket_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_is_socket_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.lstat(fpath);
- expect(stat.isSocket() === false).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_lstat_async_is_socket_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_SOCKET_0010
- * @tc.name fileIO_lstat_async_is_socket_001
- * @tc.desc Test the isSocket() method of class Stat. Callback.
- * This interface shall not treat a file as a socket.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_is_socket_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_is_socket_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.lstat(fpath, (err, stat) => {
- if (err) {
- console.log('fileIO_lstat_async_is_socket_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(stat.isSocket() === false).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_lstat_async_is_socket_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_SYMBOLIC_LINK_0000
- * @tc.name fileIO_lstat_async_is_symbolic_link_000
- * @tc.desc Test the isSymbolicLink() method of class Stat. Promise.
- * This interface shall not treat a normal file as a symbolic link.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_is_symbolic_link_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_is_symbolic_link_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.lstat(fpath);
- expect(stat.isSymbolicLink() === false).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_lstat_async_is_symbolic_link_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_SYMBOLIC_LINK_0100
- * @tc.name fileIO_lstat_async_is_symbolic_link_001
- * @tc.desc Test the isSymbolicLink() method of class Stat. Callback.
- * This interface shall not treat a normal file as a symbolic link.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_lstat_async_is_symbolic_link_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_lstat_async_is_symbolic_link_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.lstat(fpath, (err, stat) => {
- if (err) {
- console.log('fileIO_lstat_async_is_symbolic_link_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(stat.isSymbolicLink() === false).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_lstat_async_is_symbolic_link_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_APPEND_FILE_SYNC_0010
- * @tc.name fileIO_test_append_file_sync_000
- * @tc.desc Test lstat.lstatSync() interface.
- * Modify the file, view the file status changes by path.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_append_file_sync_000', 0, async function () {
- let fpath = await nextFileName('fileIO_test_append_file_sync_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.lstatSync(fpath);
- expect(isIntNum(stat.size)).assertTrue();
-
- let file = fileIO.openSync(fpath, fileIO.OpenMode.APPEND | fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
-
- expect(fileIO.writeSync(file.fd, FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- fileIO.closeSync(file);
-
- stat = fileIO.lstatSync(fpath);
- expect(stat.size == FILE_CONTENT.length * 2).assertTrue();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_append_file_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-})
-}
+/*
+ * Copyright (C) 2023 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import {
+ fileIO, FILE_CONTENT, prepareFile, nextFileName, isIntNum, isBigInt,
+ describe, it, expect,
+} from '../Common';
+
+export default function fileIOLstat() {
+describe('fileIO_fs_lstat', function () {
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_SYNC_0000
+ * @tc.name fileIO_lstat_sync_000
+ * @tc.desc Test lstatSync() interface.
+ * Enter the path parameter to get the file stat.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_lstat_sync_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_lstat_sync_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.lstatSync(fpath);
+ expect(stat !== null).assertTrue();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_lstat_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_SYNC_0100
+ * @tc.name fileIO_lstat_sync_001
+ * @tc.desc Test lstatSync() interface.
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_sync_001', 0, async function () {
+ let fpath = await nextFileName('fileIO_lstat_sync_001');
+
+ try {
+ fileIO.lstatSync(fpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_lstat_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_SYNC_0200
+ * @tc.name fileIO_lstat_sync_002
+ * @tc.desc Test lstatSync() interface.
+ * Missing parameters.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_sync_002', 0, async function () {
+
+ try {
+ fileIO.lstatSync();
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_lstat_sync_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_INO_0000
+ * @tc.name fileIO_lstat_ino_000
+ * @tc.desc Test the ino member of class Stat.
+ * Enter the path parameter to get stat.ino of the file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_ino_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_lstat_ino_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ try {
+ let stat = fileIO.lstatSync(fpath);
+ expect(isBigInt(stat.ino)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_lstat_ino_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_MODE_0000
+ * @tc.name fileIO_lstat_mode_000
+ * @tc.desc Test the mode member of class Stat.
+ * Enter the path parameter to get stat.mode of the file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_mode_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_lstat_mode_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.lstatSync(fpath);
+ expect(isIntNum(stat.mode)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_lstat_mode_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_UID_0000
+ * @tc.name fileIO_lstat_uid_000
+ * @tc.desc Test the uid member of class Stat.
+ * Enter the path parameter to get stat.uid of the file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_uid_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_lstat_uid_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.lstatSync(fpath);
+ expect(isIntNum(stat.uid)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_lstat_uid_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_GID_0000
+ * @tc.name fileIO_lstat_gid_000
+ * @tc.desc Test the gid member of class Stat.
+ * Enter the path parameter to get stat.gid of the file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_gid_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_lstat_gid_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.lstatSync(fpath);
+ expect(isIntNum(stat.gid)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_lstat_gid_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_SIZE_0000
+ * @tc.name fileIO_lstat_size_000
+ * @tc.desc Test the size member of class Stat.
+ * Enter the path parameter to get stat.size of the file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_size_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_lstat_size_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.lstatSync(fpath);
+ expect(isIntNum(stat.size)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_lstat_size_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ATIME_0000
+ * @tc.name fileIO_lstat_atime_000
+ * @tc.desc Test the atime member of class Stat.
+ * Enter the path or parameter to get stat.atime of the file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_atime_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_lstat_atime_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.lstatSync(fpath);
+ expect(isIntNum(stat.atime)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_lstat_atime_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_MTIME_0000
+ * @tc.name fileIO_lstat_mtime_000
+ * @tc.desc Test the mtime member of class Stat.
+ * Enter the path parameter to get stat.mtime of the file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_mtime_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_lstat_mtime_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.lstatSync(fpath);
+ expect(isIntNum(stat.mtime)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_lstat_mtime_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_CTIME_0000
+ * @tc.name fileIO_lstat_ctime_000
+ * @tc.desc Test the ctime member of class Stat.
+ * Enter the path parameter to get stat.ctime of the file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_ctime_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_lstat_ctime_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.lstatSync(fpath);
+ expect(isIntNum(stat.ctime)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_lstat_ctime_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_IS_BLOCK_DEVICE_0000
+ * @tc.name fileIO_lstat_is_block_device_000
+ * @tc.desc Test Lstat.isBlockDevice() interface.
+ * This interface shall not treat a normal file as a block special device.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_is_block_device_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_lstat_is_block_device_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.lstatSync(fpath);
+ expect(stat.isBlockDevice() === false).assertTrue();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_lstat_is_block_device_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_IS_BLOCK_DEVICE_0100
+ * @tc.name fileIO_test_lstat_is_block_device_001
+ * @tc.desc Test Lstat.isBlockDevice() interface.
+ * This interface does not require parameters.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_lstat_is_block_device_001', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_lstat_is_block_device_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.lstatSync(fpath).isBlockDevice(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_lstat_is_block_device_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_IS_CHARACTER_DEVICE_0000
+ * @tc.name fileIO_lstat_is_character_device_000
+ * @tc.desc Test Lstat.isCharacterDevice() interface.
+ * This interface shall not treat a normal file as a character special device.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_is_character_device_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_lstat_is_character_device_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.lstatSync(fpath);
+ expect(stat.isCharacterDevice() === false).assertTrue();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_lstat_is_character_device_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_IS_CHARACTER_DEVICE_0100
+ * @tc.name fileIO_lstat_is_character_device_001
+ * @tc.desc Test Lstat.isCharacterDevice() interface.
+ * This interface does not require parameters.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_lstat_is_character_device_001', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_lstat_is_character_device_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.lstatSync(fpath).isCharacterDevice(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_lstat_is_character_device_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_IS_DIRECTORY_0000
+ * @tc.name fileIO_lstat_is_directory_000
+ * @tc.desc Test Lstat.isDirectory() interface.
+ * This interface shall not treat a normal file as a directory.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_is_directory_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_lstat_is_directory_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.lstatSync(fpath);
+ expect(stat.isDirectory() === false).assertTrue();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_lstat_is_directory_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_IS_DIRECTORY_0100
+ * @tc.name fileIO_lstat_is_directory_001
+ * @tc.desc Test Lstat.isDirectory() interface.
+ * This interface shall treat a directory as a directory.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_is_directory_001', 0, async function () {
+ let dpath = await nextFileName('fileIO_lstat_is_directory_001') + 'd';
+
+ try {
+ fileIO.mkdirSync(dpath);
+ let stat = fileIO.lstatSync(dpath);
+ expect(stat.isDirectory() === true).assertTrue();
+ fileIO.rmdirSync(dpath);
+ } catch (e) {
+ console.log('fileIO_lstat_is_directory_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_IS_DIRECTORY_0200
+ * @tc.name fileIO_lstat_is_directory_002
+ * @tc.desc Test Lstat.isDirectory() interface.
+ * This interface does not require parameters.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_is_directory_002', 0, async function () {
+ let dpath = await nextFileName('fileIO_lstat_is_directory_002') + 'd';
+
+ try {
+ fileIO.mkdirSync(dpath);
+ fileIO.lstatSync(dpath).isDirectory(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.rmdirSync(dpath);
+ console.log('fileIO_lstat_is_directory_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_IS_FIFO_0000
+ * @tc.name fileIO_lstat_is_fifo_000
+ * @tc.desc Test Lstat.isFIFO() interface.
+ * This interface shall not treat a normal file as a FIFO.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_is_fifo_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_lstat_is_fifo_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.lstatSync(fpath);
+ expect(stat.isFIFO() === false).assertTrue();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_lstat_is_fifo_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_IS_FIFO_0100
+ * @tc.name fileIO_lstat_is_fifo_001
+ * @tc.desc Test Lstat.isFIFO() interface.
+ * This interface does not require parameters.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_lstat_is_fifo_002', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_lstat_is_fifo_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.lstatSync(fpath).isFIFO(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_lstat_is_fifo_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_IS_FILE_0000
+ * @tc.name fileIO_lstat_is_file_000
+ * @tc.desc Test Lstat.isFile() interface.
+ * This interface shall treat a normal file as a normal file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_is_file_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_lstat_is_file_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.lstatSync(fpath);
+ expect(stat.isFile() === true).assertTrue();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_lstat_is_file_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_IS_FILE_0100
+ * @tc.name fileIO_lstat_is_file_001
+ * @tc.desc Test Lstat.isFile() interface.
+ * This interface shall not treat a directory as a normal file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_is_file_001', 0, async function () {
+ let dpath = await nextFileName('fileIO_lstat_is_file_001');
+
+ try {
+ fileIO.mkdirSync(dpath);
+ let stat = fileIO.lstatSync(dpath);
+ expect(stat.isFile() === false).assertTrue();
+ fileIO.rmdirSync(dpath);
+ } catch (e) {
+ console.log('fileIO_lstat_is_file_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_IS_FILE_0200
+ * @tc.name fileIO_test_lstat_is_file_002
+ * @tc.desc Test Lstat.isFile() interface.
+ * This interface does not require parameters.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_lstat_is_file_002', 0, async function () {
+ let dpath = await nextFileName('fileIO_test_lstat_is_file_002');
+
+ try {
+ fileIO.mkdirSync(dpath);
+ fileIO.lstatSync(dpath).isFile(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.rmdirSync(dpath);
+ console.log('fileIO_test_lstat_is_file_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_IS_SOCKET_0000
+ * @tc.name fileIO_lstat_is_socket_000
+ * @tc.desc Test Lstat.isSocket() interface.
+ * This interface shall not treat a file as a socket.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_is_socket_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_lstat_is_socket_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.lstatSync(fpath);
+ expect(stat.isSocket() === false).assertTrue();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_lstat_is_socket_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_IS_SOCKET_0100
+ * @tc.name fileIO_lstat_is_socket_001
+ * @tc.desc Test Lstat.isSocket() interface.
+ * This interface does not require parameters.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_is_socket_001', 0, async function () {
+ let fpath = await nextFileName('fileIO_lstat_is_socket_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.lstatSync(fpath).isSocket(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_lstat_is_socket_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_IS_SYMBOLIC_LINK_0000
+ * @tc.name fileIO_lstat_is_symbolic_link_000
+ * @tc.desc Test Lstat.isSymbolicLink() interface.
+ * This interface shall not treat a normal file as a symbolic link.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_is_symbolic_link_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_lstat_is_symbolic_link_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.lstatSync(fpath);
+ expect(stat.isSymbolicLink() === false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_lstat_is_symbolic_link_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_IS_SYMBOLIC_LINK_0100
+ * @tc.name fileIO_lstat_is_symbolic_link_001
+ * @tc.desc Test Lstat.isSymbolicLink() interface.
+ * This interface does not require parameters.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_is_symbolic_link_001', 0, async function () {
+ let fpath = await nextFileName('fileIO_lstat_is_symbolic_link_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.lstatSync(fpath).isSymbolicLink(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_lstat_is_symbolic_link_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_0000
+ * @tc.name fileIO_lstat_async_000
+ * @tc.desc Test lstat() interface. Promise.then().catch()
+ * Enter the path parameter to get the file stat.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_lstat_async_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.lstat(fpath).then((stat) => {
+ expect(stat !== null).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ }).catch((err) => {
+ console.log('fileIO_lstat_async_000 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ console.log('fileIO_lstat_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_0100
+ * @tc.name fileIO_lstat_async_001
+ * @tc.desc Test lstat() interface. Callback.
+ * Enter the path or parameter to get the file stat.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.lstat(fpath, (err) => {
+ if(err) {
+ console.log('fileIO_lstat_async_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_lstat_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_0200
+ * @tc.name fileIO_lstat_async_002
+ * @tc.desc Test lstat() interface. Promise.
+ * Enter the path or parameter to get the file stat.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_002', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.lstat(fpath);
+ expect(stat !== null).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_lstat_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_0300
+ * @tc.name fileIO_lstat_async_003
+ * @tc.desc Test lstat() interface.
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_003', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_003');
+
+ try {
+ fileIO.lstat(fpath, (err) => {
+ if (err) {
+ console.log('fileIO_lstat_async_003 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('fileIO_lstat_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_0400
+ * @tc.name fileIO_lstat_async_004
+ * @tc.desc Test lstat() interface. Promise.
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_004', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_004');
+
+ try {
+ await fileIO.lstat(fpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_lstat_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_INO_0000
+ * @tc.name fileIO_lstat_async_ino_000
+ * @tc.desc Test the ino member of class Stat. Promise.
+ * Enter the path parameter to get stat.ino of the file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_ino_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_ino_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.lstat(fpath);
+ expect(isBigInt(stat.ino)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_lstat_async_ino_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_INO_0100
+ * @tc.name fileIO_lstat_async_ino_001
+ * @tc.desc Test the ino member of class Stat. Callback.
+ * Enter the path parameter to get stat.ino of the file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_ino_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_ino_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.lstat(fpath, (err, stat) => {
+ if(err) {
+ console.log('fileIO_lstat_async_ino_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isBigInt(stat.ino)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_lstat_async_ino_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_MODE_0000
+ * @tc.name fileIO_lstat_async_mode_000
+ * @tc.desc Test the mode member of class Stat. Promise.
+ * Enter the path or parameter to get stat.mode of the file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_mode_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_mode_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.lstat(fpath);
+ expect(isIntNum(stat.mode)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_lstat_async_mode_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_MODE_0100
+ * @tc.name fileIO_lstat_async_mode_001
+ * @tc.desc Test the mode member of class Stat. Callback.
+ * Enter the path or parameter to get stat.mode of the file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_mode_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_mode_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.lstat(fpath, (err, stat) => {
+ if(err) {
+ console.log('fileIO_lstat_async_mode_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(stat.mode)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_lstat_async_mode_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_UID_0000
+ * @tc.name fileIO_lstat_async_uid_000
+ * @tc.desc Test the uid member of class Stat. Promise.
+ * Enter the path parameter to get stat.uid of the file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_uid_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_uid_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.lstat(fpath);
+ expect(isIntNum(stat.uid)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_lstat_async_uid_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_UID_0100
+ * @tc.name fileIO_lstat_async_uid_001
+ * @tc.desc Test the uid member of class Stat. Callback.
+ * Enter the path parameter to get stat.uid of the file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_uid_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_uid_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.lstat(fpath, (err, stat) => {
+ if(err) {
+ console.log('fileIO_lstat_async_uid_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(stat.uid)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_lstat_async_uid_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_GID_0000
+ * @tc.name fileIO_lstat_async_gid_000
+ * @tc.desc Test the gid member of class Stat. Promise.
+ * Enter the path parameter to get stat.gid of the file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_gid_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_gid_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.lstat(fpath);
+ expect(isIntNum(stat.gid)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_lstat_async_gid_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_GID_0100
+ * @tc.name fileIO_lstat_async_gid_001
+ * @tc.desc Test the gid member of class Stat. Callback.
+ * Enter the path parameter to get stat.gid of the file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_gid_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_gid_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.lstat(fpath, (err, stat) => {
+ if (err) {
+ console.log('fileIO_lstat_async_gid_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(stat.gid)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_lstat_async_gid_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_SIZE_0000
+ * @tc.name fileIO_lstat_async_size_000
+ * @tc.desc Test the size member of class Stat. Promise.
+ * Enter the path parameter to get stat.size of the file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_size_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_size_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.lstat(fpath);
+ expect(isIntNum(stat.size)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_lstat_async_size_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_SIZE_0100
+ * @tc.name fileIO_lstat_async_size_001
+ * @tc.desc Test the size member of class Stat. Callback.
+ * Enter the path parameter to get stat.size of the file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_size_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_size_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.lstat(fpath, (err, stat) => {
+ if (err) {
+ console.log('fileIO_lstat_async_size_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(stat.size)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_lstat_async_size_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_ATIME_0000
+ * @tc.name fileIO_lstat_async_atime_000
+ * @tc.desc Test the atime member of class Stat. Promise.
+ * Enter the path parameter to get stat.atime of the file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_atime_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_atime_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.lstat(fpath);
+ expect(isIntNum(stat.atime)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_lstat_async_atime_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_ATIME_0100
+ * @tc.name fileIO_lstat_async_atime_001
+ * @tc.desc Test the atime member of class Stat. Callback.
+ * Enter the path or fd parameter to get stat.atime of the file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_atime_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_atime_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.lstat(fpath, (err, stat) => {
+ if (err) {
+ console.log('fileIO_lstat_async_atime_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(stat.atime)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_lstat_async_atime_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_MTIME_0000
+ * @tc.name fileIO_lstat_async_mtime_000
+ * @tc.desc Test the mtime member of class Stat. Promise.
+ * Enter the path or fd parameter to get stat.mtime of the file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_mtime_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_mtime_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.lstat(fpath);
+ expect(isIntNum(stat.mtime)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_lstat_async_mtime_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_MTIME_0100
+ * @tc.name fileIO_lstat_async_mtime_001
+ * @tc.desc Test the mtime member of class Stat. Callback.
+ * Enter the path or fd parameter to get stat.mtime of the file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_mtime_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_mtime_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.lstat(fpath, (err, stat) => {
+ if (err) {
+ console.log('fileIO_lstat_async_mtime_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(stat.mtime)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_lstat_async_mtime_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_CTIME_0000
+ * @tc.name fileIO_lstat_async_ctime_000
+ * @tc.desc Test the ctime member of class Stat. Promise.
+ * Enter the path or fd parameter to get stat.ctime of the file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_ctime_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_ctime_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.lstat(fpath);
+ expect(isIntNum(stat.ctime)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_lstat_async_ctime_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_CTIME_0100
+ * @tc.name fileIO_lstat_async_ctime_001
+ * @tc.desc Test the ctime member of class Stat. Callback.
+ * Enter the path or fd parameter to get stat.ctime of the file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_ctime_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_ctime_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.lstat(fpath, (err, stat) => {
+ if (err) {
+ console.log('fileIO_lstat_async_ctime_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(stat.ctime)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_lstat_async_ctime_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_BLOCK_DEVICE_0000
+ * @tc.name fileIO_lstat_async_is_block_device_000
+ * @tc.desc Test the isBlockDevice() method of class Stat. Promise.
+ * This interface shall not treat a normal file as a block special device.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_is_block_device_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_is_block_device_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.lstat(fpath);
+ expect(stat.isBlockDevice() === false).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_lstat_async_is_block_device_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_BLOCK_DEVICE_0010
+ * @tc.name fileIO_lstat_async_is_block_device_001
+ * @tc.desc Test the isBlockDevice() method of class Stat. Callback.
+ * This interface shall not treat a normal file as a block special device.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_is_block_device_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_is_block_device_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.lstat(fpath, (err, stat) => {
+ if (err) {
+ console.log('fileIO_lstat_async_is_block_device_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(stat.isBlockDevice() === false).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_lstat_async_is_block_device_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_CHARACTER_DEVICE_0000
+ * @tc.name fileIO_lstat_async_is_character_device_000
+ * @tc.desc Test the isCharacterDevice() method of class Stat. Promise.
+ * This interface shall not treat a normal file as a character special device.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_is_character_device_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_is_character_device_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.lstat(fpath);
+ expect(stat.isCharacterDevice() === false).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_lstat_async_is_character_device_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_CHARACTER_DEVICE_0010
+ * @tc.name fileIO_lstat_async_is_character_device_001
+ * @tc.desc Test the isCharacterDevice() method of class Stat. Callback.
+ * This interface shall not treat a normal file as a character special device.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_is_character_device_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_is_character_device_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.lstat(fpath, (err, stat) => {
+ if (err) {
+ console.log('fileIO_lstat_async_is_character_device_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(stat.isCharacterDevice() === false).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_lstat_async_is_character_device_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_DIRECTORY_0000
+ * @tc.name fileIO_lstat_async_is_directory_000
+ * @tc.desc Test the isDirectory() method of class Stat. Promise.
+ * This interface shall not treat a normal file as a directory.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_is_directory_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_is_directory_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.lstat(fpath);
+ expect(stat.isDirectory() === false).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_lstat_async_is_directory_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_DIRECTORY_0010
+ * @tc.name fileIO_lstat_async_is_directory_001
+ * @tc.desc Test the isDirectory() method of class Stat. Promise.
+ * This interface shall not treat a directory as a directory.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_is_directory_001', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_lstat_async_is_directory_001') + 'd';
+
+
+ try {
+ fileIO.mkdirSync(dpath);
+ let stat = await fileIO.lstat(dpath);
+ expect(stat.isDirectory() === true).assertTrue();
+ fileIO.rmdirSync(dpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_lstat_async_is_directory_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_DIRECTORY_0020
+ * @tc.name fileIO_lstat_async_is_directory_002
+ * @tc.desc Test the isDirectory() method of class Stat. Callback.
+ * This interface shall not treat a directory as a directory.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_is_directory_002', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_lstat_async_is_directory_002') + 'd';
+
+ try {
+ fileIO.mkdirSync(dpath);
+ fileIO.lstat(dpath, (err, stat) => {
+ if (err) {
+ console.log('fileIO_lstat_async_is_directory_002 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(stat.isDirectory() === true).assertTrue();
+ fileIO.rmdirSync(dpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_lstat_async_is_directory_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_FIFO_0000
+ * @tc.name fileIO_lstat_async_is_fifo_000
+ * @tc.desc Test the isFIFO() method of class Stat. Promise.
+ * This interface shall not treat a normal file as a FIFO.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_is_fifo_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_is_fifo_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.lstat(fpath);
+ expect(stat.isFIFO() === false).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_lstat_async_is_fifo_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_FIFO_0010
+ * @tc.name fileIO_lstat_async_is_fifo_001
+ * @tc.desc Test the isFIFO() method of class Stat. Callback.
+ * This interface shall not treat a normal file as a FIFO.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_is_fifo_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_is_fifo_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.lstat(fpath, (err, stat) => {
+ if (err) {
+ console.log('fileIO_lstat_async_is_character_device_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(stat.isFIFO() === false).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_lstat_async_is_fifo_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_FILE_0000
+ * @tc.name fileIO_lstat_async_is_file_000
+ * @tc.desc Test the isFile() method of class Stat. Promise.
+ * This interface shall treat a normal file as a normal file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_is_file_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_is_file_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.lstat(fpath);
+ expect(stat.isFile() === true).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_lstat_async_is_file_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_FILE_0010
+ * @tc.name fileIO_lstat_async_is_file_001
+ * @tc.desc Test the isFile() method of class Stat. Callback.
+ * This interface shall treat a normal file as a normal file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_is_file_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_is_file_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.lstat(fpath, (err, stat) => {
+ if (err) {
+ console.log('fileIO_lstat_async_is_file_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(stat.isFile() === true).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_lstat_async_is_file_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_FILE_0020
+ * @tc.name fileIO_lstat_async_is_file_002
+ * @tc.desc Test the isFile() method of class Stat. Promise.
+ * This interface shall not treat a directory as a normal file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_is_file_002', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_lstat_async_is_file_002');
+
+ try {
+ fileIO.mkdirSync(dpath);
+ let stat = await fileIO.lstat(dpath);
+ expect(stat.isFile() === false).assertTrue();
+ fileIO.rmdirSync(dpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_lstat_async_is_file_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_SOCKET_0000
+ * @tc.name fileIO_lstat_async_is_socket_000
+ * @tc.desc Test the isSocket() method of class Stat. Promise.
+ * This interface shall not treat a file as a socket.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_is_socket_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_is_socket_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.lstat(fpath);
+ expect(stat.isSocket() === false).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_lstat_async_is_socket_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_SOCKET_0010
+ * @tc.name fileIO_lstat_async_is_socket_001
+ * @tc.desc Test the isSocket() method of class Stat. Callback.
+ * This interface shall not treat a file as a socket.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_is_socket_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_is_socket_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.lstat(fpath, (err, stat) => {
+ if (err) {
+ console.log('fileIO_lstat_async_is_socket_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(stat.isSocket() === false).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_lstat_async_is_socket_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_SYMBOLIC_LINK_0000
+ * @tc.name fileIO_lstat_async_is_symbolic_link_000
+ * @tc.desc Test the isSymbolicLink() method of class Stat. Promise.
+ * This interface shall not treat a normal file as a symbolic link.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_is_symbolic_link_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_is_symbolic_link_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.lstat(fpath);
+ expect(stat.isSymbolicLink() === false).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_lstat_async_is_symbolic_link_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_LSTAT_ASYNC_IS_SYMBOLIC_LINK_0100
+ * @tc.name fileIO_lstat_async_is_symbolic_link_001
+ * @tc.desc Test the isSymbolicLink() method of class Stat. Callback.
+ * This interface shall not treat a normal file as a symbolic link.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_lstat_async_is_symbolic_link_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_lstat_async_is_symbolic_link_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.lstat(fpath, (err, stat) => {
+ if (err) {
+ console.log('fileIO_lstat_async_is_symbolic_link_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(stat.isSymbolicLink() === false).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_lstat_async_is_symbolic_link_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_APPEND_FILE_SYNC_0010
+ * @tc.name fileIO_test_append_file_sync_000
+ * @tc.desc Test lstat.lstatSync() interface.
+ * Modify the file, view the file status changes by path.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_append_file_sync_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_append_file_sync_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.lstatSync(fpath);
+ expect(isIntNum(stat.size)).assertTrue();
+
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.APPEND | fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+
+ expect(fileIO.writeSync(file.fd, FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ fileIO.closeSync(file);
+
+ stat = fileIO.lstatSync(fpath);
+ expect(stat.size == FILE_CONTENT.length * 2).assertTrue();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_append_file_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+})
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/mkdir.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/mkdir.test.js
similarity index 96%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/mkdir.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/mkdir.test.js
index 17b5fb5ec03c9c9163641414e1aff4366fd472f7..3791177fca0738d237e210333e64dffe678e88f5 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/mkdir.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/members/mkdir.test.js
@@ -1,235 +1,235 @@
-/*
- * Copyright (C) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the 'License');
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an 'AS IS' BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import {
- fileIO, nextFileName, describe, it, expect, prepareFile, FILE_CONTENT,
-} from '../Common';
-
-export default function fileIOMkdir() {
-describe('fileIO_fs_mkdir', function () {
-
- /**
- * @tc.number SUB_DF_FILEIO_MKDIR_SYNC_0000
- * @tc.name fileIO_test_mkdir_sync_000
- * @tc.desc Test mkdirSync() interfaces.
- * Create a directory, verify normal function.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_mkdir_sync_000', 0, async function () {
- let dpath = await nextFileName('fileIO_test_mkdir_sync_000') + 'd';
-
- try {
- fileIO.mkdirSync(dpath);
- expect(fileIO.accessSync(dpath)).assertTrue();
- fileIO.rmdirSync(dpath);
- } catch (e) {
- console.log('fileIO_test_mkdir_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MKDIR_SYNC_0100
- * @tc.name fileIO_test_mkdir_sync_001
- * @tc.desc Test mkdirSync() interfaces.
- * The directory has been existed.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_mkdir_sync_001', 0, async function () {
-
- try {
- fileIO.mkdirSync('/');
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_mkdir_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900015 && e.message == 'File exists').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MKDIR_SYNC_0200
- * @tc.name fileIO_test_mkdir_sync_002
- * @tc.desc Test mkdirSync() interfaces.
- * The path is empty.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_mkdir_sync_002', 0, async function () {
-
- try {
- fileIO.mkdirSync('');
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_mkdir_sync_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MKDIR_SYNC_0300
- * @tc.name fileIO_test_mkdir_sync_003
- * @tc.desc Test mkdirSync() interfaces.
- * The path has pointed to a file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_mkdir_sync_003', 0, async function () {
- let fpath = await nextFileName('fileIO_test_mkdir_sync_003');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.mkdirSync(fpath);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_mkdir_sync_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900015 && e.message == 'File exists').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MKDIR_ASYNC_0000
- * @tc.name fileIO_test_mkdir_async_000
- * @tc.desc Test mkdir() interfaces. Promise.
- * Create a directory, verify normal function.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_mkdir_async_000', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_mkdir_async_000') + 'd';
-
- try {
- await fileIO.mkdir(dpath);
- expect(fileIO.accessSync(dpath)).assertTrue();
- fileIO.rmdirSync(dpath);
- done();
- } catch (e) {
- console.log('fileIO_test_mkdir_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MKDIR_ASYNC_0100
- * @tc.name fileIO_test_mkdir_async_001
- * @tc.desc Test mkdir() interfaces. Callback.
- * Create a directory, verify normal function.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_mkdir_async_001', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_mkdir_async_001') + 'd';
-
- try {
- fileIO.mkdir(dpath, (err) => {
- if(err) {
- console.log('fileIO_test_mkdir_async_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(fileIO.accessSync(dpath)).assertTrue();
- fileIO.rmdirSync(dpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_mkdir_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MKDIR_ASYNC_0200
- * @tc.name fileIO_test_mkdir_async_002
- * @tc.desc Test mkdir() interfaces. Promise.
- * Missing parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_mkdir_async_002', 0, async function (done) {
-
- try {
- await fileIO.mkdir();
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_mkdir_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MKDIR_ASYNC_0300
- * @tc.name fileIO_test_mkdir_async_003
- * @tc.desc Test mkdir() interfaces. Callback.
- * The directory has been existed.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_mkdir_async_003', 0, async function (done) {
-
- try {
- fileIO.mkdir('/', (err) => {
- if(err) {
- console.log('fileIO_test_mkdir_async_003 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900015 && err.message == 'File exists').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('fileIO_test_mkdir_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MKDIR_ASYNC_0400
- * @tc.name fileIO_test_mkdir_async_004
- * @tc.desc Test mkdir() interfaces. Promise.
- * The path has pointed to a file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_mkdir_async_004', 0, async function () {
- let fpath = await nextFileName('fileIO_test_mkdir_async_004');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- await fileIO.mkdirSync(fpath);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_mkdir_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900015 && e.message == 'File exists').assertTrue();
- }
- });
-})
-}
+/*
+ * Copyright (C) 2023 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import {
+ fileIO, nextFileName, describe, it, expect, prepareFile, FILE_CONTENT,
+} from '../Common';
+
+export default function fileIOMkdir() {
+describe('fileIO_fs_mkdir', function () {
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MKDIR_SYNC_0000
+ * @tc.name fileIO_test_mkdir_sync_000
+ * @tc.desc Test mkdirSync() interfaces.
+ * Create a directory, verify normal function.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_mkdir_sync_000', 0, async function () {
+ let dpath = await nextFileName('fileIO_test_mkdir_sync_000') + 'd';
+
+ try {
+ fileIO.mkdirSync(dpath);
+ expect(fileIO.accessSync(dpath)).assertTrue();
+ fileIO.rmdirSync(dpath);
+ } catch (e) {
+ console.log('fileIO_test_mkdir_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MKDIR_SYNC_0100
+ * @tc.name fileIO_test_mkdir_sync_001
+ * @tc.desc Test mkdirSync() interfaces.
+ * The directory has been existed.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_mkdir_sync_001', 0, async function () {
+
+ try {
+ fileIO.mkdirSync('/');
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_mkdir_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900015 && e.message == 'File exists').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MKDIR_SYNC_0200
+ * @tc.name fileIO_test_mkdir_sync_002
+ * @tc.desc Test mkdirSync() interfaces.
+ * The path is empty.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_mkdir_sync_002', 0, async function () {
+
+ try {
+ fileIO.mkdirSync('');
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_mkdir_sync_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MKDIR_SYNC_0300
+ * @tc.name fileIO_test_mkdir_sync_003
+ * @tc.desc Test mkdirSync() interfaces.
+ * The path has pointed to a file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_mkdir_sync_003', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_mkdir_sync_003');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.mkdirSync(fpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_mkdir_sync_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900015 && e.message == 'File exists').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MKDIR_ASYNC_0000
+ * @tc.name fileIO_test_mkdir_async_000
+ * @tc.desc Test mkdir() interfaces. Promise.
+ * Create a directory, verify normal function.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_mkdir_async_000', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_mkdir_async_000') + 'd';
+
+ try {
+ await fileIO.mkdir(dpath);
+ expect(fileIO.accessSync(dpath)).assertTrue();
+ fileIO.rmdirSync(dpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_mkdir_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MKDIR_ASYNC_0100
+ * @tc.name fileIO_test_mkdir_async_001
+ * @tc.desc Test mkdir() interfaces. Callback.
+ * Create a directory, verify normal function.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_mkdir_async_001', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_mkdir_async_001') + 'd';
+
+ try {
+ fileIO.mkdir(dpath, (err) => {
+ if(err) {
+ console.log('fileIO_test_mkdir_async_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(fileIO.accessSync(dpath)).assertTrue();
+ fileIO.rmdirSync(dpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_mkdir_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MKDIR_ASYNC_0200
+ * @tc.name fileIO_test_mkdir_async_002
+ * @tc.desc Test mkdir() interfaces. Promise.
+ * Missing parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_mkdir_async_002', 0, async function (done) {
+
+ try {
+ await fileIO.mkdir();
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_mkdir_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MKDIR_ASYNC_0300
+ * @tc.name fileIO_test_mkdir_async_003
+ * @tc.desc Test mkdir() interfaces. Callback.
+ * The directory has been existed.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_mkdir_async_003', 0, async function (done) {
+
+ try {
+ fileIO.mkdir('/', (err) => {
+ if(err) {
+ console.log('fileIO_test_mkdir_async_003 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900015 && err.message == 'File exists').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('fileIO_test_mkdir_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MKDIR_ASYNC_0400
+ * @tc.name fileIO_test_mkdir_async_004
+ * @tc.desc Test mkdir() interfaces. Promise.
+ * The path has pointed to a file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_mkdir_async_004', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_mkdir_async_004');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ await fileIO.mkdirSync(fpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_mkdir_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900015 && e.message == 'File exists').assertTrue();
+ }
+ });
+})
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/mkdtemp.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/mkdtemp.test.js
similarity index 96%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/mkdtemp.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/mkdtemp.test.js
index efa1c9612d3fddca84ea7990252b657786cad5bc..aee25dd85c0f0893d671025230fa458073067c2e 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/mkdtemp.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/members/mkdtemp.test.js
@@ -1,215 +1,215 @@
-/*
- * Copyright (C) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the 'License');
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an 'AS IS' BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import { fileIO, nextFileName, describe, it, expect } from '../Common';
-
-export default function fileIOMkdtemp() {
-describe('fileIO_fs_mkdtemp', function () {
-
- /**
- * @tc.number SUB_DF_FILEIO_MKDTEMP_SYNC_0000
- * @tc.name fileIO_test_mkdtemp_sync_000
- * @tc.desc Test mkdtempSync() interface.
- * Create a temporary directory, verify the normal function.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_mkdtemp_sync_000', 0, async function () {
- let dpath = await nextFileName('fileIO_test_mkdtemp_sync_000');
-
- try {
- dpath = dpath + 'XXXXXX';
- let res = fileIO.mkdtempSync(dpath);
- expect(fileIO.accessSync(res)).assertTrue();
- fileIO.rmdirSync(res);
- } catch (e) {
- console.log('fileIO_test_mkdtemp_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MKDTEMP_SYNC_0100
- * @tc.name fileIO_test_mkdtemp_sync_001
- * @tc.desc Test mkdtempSync() interface.
- * The directory should end in XXXXXX.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_mkdtemp_sync_001', 0, async function () {
- let dpath = await nextFileName('fileIO_test_mkdtemp_sync_000');
-
- try {
- fileIO.mkdtempSync(dpath);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_mkdtemp_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MKDTEMP_SYNC_0200
- * @tc.name fileIO_test_mkdtemp_sync_002
- * @tc.desc Test mkdtempSync() interface.
- * Missing parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_mkdtemp_sync_002', 0, async function () {
-
- try {
- fileIO.mkdtempSync();
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_mkdtemp_sync_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MKDTEMP_ASYNC_0000
- * @tc.name fileIO_test_mkdtemp_async_000
- * @tc.desc Test mkdtemp() interface. Promise.
- * Create a temporary directory, verify the normal function.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_mkdtemp_async_000', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_mkdtemp_async_000');
-
- try {
- dpath = dpath + 'XXXXXX';
- let res = await fileIO.mkdtemp(dpath);
- expect(fileIO.accessSync(res)).assertTrue();
- fileIO.rmdirSync(res);
- done();
- } catch (e) {
- console.log('fileIO_test_mkdtemp_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MKDTEMP_ASYNC_0100
- * @tc.name fileIO_test_mkdtemp_async_001
- * @tc.desc Test mkdtemp() interface. Callback.
- * Create a temporary directory, verify the normal function.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_mkdtemp_async_001', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_mkdtemp_async_001');
-
- try {
- dpath = dpath + 'XXXXXX';
- fileIO.mkdtemp(dpath, (err, res) => {
- if (err) {
- console.log('fileIO_test_mkdtemp_async_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(fileIO.accessSync(res)).assertTrue();
- fileIO.rmdirSync(res);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_mkdtemp_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MKDTEMP_ASYNC_0200
- * @tc.name fileIO_test_mkdtemp_async_002
- * @tc.desc Test mkdtemp() interface. Promise.
- * The directory should end in XXXXXX.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_mkdtemp_async_002', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_mkdtemp_async_002');
-
- try {
- await fileIO.mkdtemp(dpath);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_mkdtemp_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MKDTEMP_ASYNC_0300
- * @tc.name fileIO_test_mkdtemp_async_003
- * @tc.desc Test mkdtemp() interface. Callback.
- * The directory should end in XXXXXX.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_mkdtemp_async_003', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_mkdtemp_async_003');
-
- try {
- fileIO.mkdtemp(dpath, (err) => {
- if (err) {
- console.log('fileIO_test_mkdtemp_async_003 error package: ' + JSON.stringify(err));
- expect(err.code == 13900020 && err.message == 'Invalid argument').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('fileIO_test_mkdtemp_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MKDTEMP_ASYNC_0400
- * @tc.name fileIO_test_mkdtemp_async_004
- * @tc.desc Test mkdtemp() interface. Promise.
- * Missing parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_mkdtemp_async_004', 0, async function (done) {
-
- try {
- await fileIO.mkdtemp();
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_mkdtemp_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-});
-}
+/*
+ * Copyright (C) 2023 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import { fileIO, nextFileName, describe, it, expect } from '../Common';
+
+export default function fileIOMkdtemp() {
+describe('fileIO_fs_mkdtemp', function () {
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MKDTEMP_SYNC_0000
+ * @tc.name fileIO_test_mkdtemp_sync_000
+ * @tc.desc Test mkdtempSync() interface.
+ * Create a temporary directory, verify the normal function.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_mkdtemp_sync_000', 0, async function () {
+ let dpath = await nextFileName('fileIO_test_mkdtemp_sync_000');
+
+ try {
+ dpath = dpath + 'XXXXXX';
+ let res = fileIO.mkdtempSync(dpath);
+ expect(fileIO.accessSync(res)).assertTrue();
+ fileIO.rmdirSync(res);
+ } catch (e) {
+ console.log('fileIO_test_mkdtemp_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MKDTEMP_SYNC_0100
+ * @tc.name fileIO_test_mkdtemp_sync_001
+ * @tc.desc Test mkdtempSync() interface.
+ * The directory should end in XXXXXX.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_mkdtemp_sync_001', 0, async function () {
+ let dpath = await nextFileName('fileIO_test_mkdtemp_sync_000');
+
+ try {
+ fileIO.mkdtempSync(dpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_mkdtemp_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MKDTEMP_SYNC_0200
+ * @tc.name fileIO_test_mkdtemp_sync_002
+ * @tc.desc Test mkdtempSync() interface.
+ * Missing parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_mkdtemp_sync_002', 0, async function () {
+
+ try {
+ fileIO.mkdtempSync();
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_mkdtemp_sync_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MKDTEMP_ASYNC_0000
+ * @tc.name fileIO_test_mkdtemp_async_000
+ * @tc.desc Test mkdtemp() interface. Promise.
+ * Create a temporary directory, verify the normal function.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_mkdtemp_async_000', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_mkdtemp_async_000');
+
+ try {
+ dpath = dpath + 'XXXXXX';
+ let res = await fileIO.mkdtemp(dpath);
+ expect(fileIO.accessSync(res)).assertTrue();
+ fileIO.rmdirSync(res);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_mkdtemp_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MKDTEMP_ASYNC_0100
+ * @tc.name fileIO_test_mkdtemp_async_001
+ * @tc.desc Test mkdtemp() interface. Callback.
+ * Create a temporary directory, verify the normal function.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_mkdtemp_async_001', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_mkdtemp_async_001');
+
+ try {
+ dpath = dpath + 'XXXXXX';
+ fileIO.mkdtemp(dpath, (err, res) => {
+ if (err) {
+ console.log('fileIO_test_mkdtemp_async_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(fileIO.accessSync(res)).assertTrue();
+ fileIO.rmdirSync(res);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_mkdtemp_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MKDTEMP_ASYNC_0200
+ * @tc.name fileIO_test_mkdtemp_async_002
+ * @tc.desc Test mkdtemp() interface. Promise.
+ * The directory should end in XXXXXX.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_mkdtemp_async_002', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_mkdtemp_async_002');
+
+ try {
+ await fileIO.mkdtemp(dpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_mkdtemp_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MKDTEMP_ASYNC_0300
+ * @tc.name fileIO_test_mkdtemp_async_003
+ * @tc.desc Test mkdtemp() interface. Callback.
+ * The directory should end in XXXXXX.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_mkdtemp_async_003', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_mkdtemp_async_003');
+
+ try {
+ fileIO.mkdtemp(dpath, (err) => {
+ if (err) {
+ console.log('fileIO_test_mkdtemp_async_003 error package: ' + JSON.stringify(err));
+ expect(err.code == 13900020 && err.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('fileIO_test_mkdtemp_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MKDTEMP_ASYNC_0400
+ * @tc.name fileIO_test_mkdtemp_async_004
+ * @tc.desc Test mkdtemp() interface. Promise.
+ * Missing parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_mkdtemp_async_004', 0, async function (done) {
+
+ try {
+ await fileIO.mkdtemp();
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_mkdtemp_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+});
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/moveDir.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/moveDir.test.js
old mode 100644
new mode 100755
similarity index 100%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/moveDir.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/moveDir.test.js
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/moveFile.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/moveFile.test.js
similarity index 97%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/moveFile.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/moveFile.test.js
index ff8435d277e205e4dbdf603b1654222a4da86589..b3d3a761213cac9cfedce9e4d79eeb128dcaa857 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/moveFile.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/members/moveFile.test.js
@@ -1,635 +1,635 @@
-/*
- * Copyright (C) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the 'License');
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an 'AS IS' BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import {
- fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect,
-} from '../Common';
-
-export default function fileIOMoveFile() {
- describe('fileIO_fs_moveFile', function () {
-
- /**
- * @tc.number SUB_DF_FILEIO_MOVEFILE_SYNC_0000
- * @tc.name fileIO_test_moveFile_sync_000
- * @tc.desc Test moveFileSync() interface.
- * Move a single file, shall work properly in normal case.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_moveFile_sync_000', 0, async function () {
- let dpath = await nextFileName('fileIO_test_moveFile_sync_000');
- let fpath = dpath + '/file_000.txt';
- let ddpath = dpath + '/dir_000';
- let ffpath = ddpath + '/file_000.txt';
- fileIO.mkdirSync(dpath);
- fileIO.mkdirSync(ddpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.moveFileSync(fpath, ffpath);
- let stat = fileIO.statSync(ffpath);
- expect(stat.size == FILE_CONTENT.length).assertTrue();
- fileIO.rmdirSync(dpath);
- } catch (e) {
- console.log('fileIO_test_moveFile_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MOVEFILE_SYNC_0100
- * @tc.name fileIO_test_moveFile_sync_001
- * @tc.desc Test moveFileSync() interface.
- * A file with the same name already exists under the destination path.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_moveFile_sync_001', 0, async function () {
- let dpath = await nextFileName('fileIO_test_moveFile_sync_001');
- let fpath = dpath + '/file_001.txt';
- let ddpath = dpath + '/dir_001';
- let ffpath = ddpath + '/file_001.txt';
- fileIO.mkdirSync(dpath);
- fileIO.mkdirSync(ddpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.copyFileSync(fpath, ffpath);
- fileIO.moveFileSync(fpath, ffpath, 1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.rmdirSync(dpath);
- console.log('fileIO_test_moveFile_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900015 && e.message == 'File exists').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MOVEFILE_SYNC_0200
- * @tc.name fileIO_test_moveFile_sync_002
- * @tc.desc Test moveFileSync() interface.
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_moveFile_sync_002', 0, async function () {
- let dpath = await nextFileName('fileIO_test_moveFile_sync_002');
- let fpath = dpath + '/file_002.txt';
- let ddpath = dpath + '/dir_002';
- let ffpath = ddpath + '/file_002.txt';
- fileIO.mkdirSync(dpath);
- fileIO.mkdirSync(ddpath);
-
- try {
- fileIO.moveFileSync(fpath, ffpath);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.rmdirSync(dpath);
- console.log('fileIO_test_moveFile_sync_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MOVEFILE_SYNC_0400
- * @tc.name fileIO_test_moveFile_sync_004
- * @tc.desc Test moveFileSync() interface.
- * The path point to a directory, not a file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_moveFile_sync_004', 0, async function () {
- let dpath = await nextFileName('fileIO_test_moveFile_sync_004');
- let ddpath = dpath + '/dir_003';
- fileIO.mkdirSync(dpath);
-
- try {
- fileIO.moveFileSync(dpath, ddpath);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.rmdirSync(dpath);
- console.log('fileIO_test_moveFile_sync_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MOVEFILE_SYNC_0500
- * @tc.name fileIO_test_moveFile_sync_005
- * @tc.desc Test moveFileSync() interface.
- * Missing parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_moveFile_sync_005', 0, async function () {
- let fpath = await nextFileName('fileIO_test_moveFile_sync_005');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.moveFileSync(fpath);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_moveFile_sync_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MOVEFILE_SYNC_0600
- * @tc.name fileIO_test_moveFile_sync_006
- * @tc.desc Test moveFileSync() interface.
- * Entry parameters increase forced movement when mode = 0.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_moveFile_sync_006', 0, async function () {
- let dpath = await nextFileName('fileIO_test_moveFile_sync_006');
- let fpath = dpath + '/file_004.txt';
- let ddpath = dpath + '/dir_004';
- let ffpath = ddpath + '/file_004.txt';
- fileIO.mkdirSync(dpath);
- fileIO.mkdirSync(ddpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- expect(prepareFile(ffpath, '')).assertTrue();
-
- try {
- fileIO.moveFileSync(fpath, ffpath, 0);
- let stat = fileIO.statSync(ffpath);
- expect(stat.size == FILE_CONTENT.length).assertTrue();
- fileIO.rmdirSync(dpath);
- } catch (e) {
- console.log('fileIO_test_moveFile_sync_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MOVEFILE_SYNC_0700
- * @tc.name fileIO_test_moveFile_sync_007
- * @tc.desc Test moveFileSync() interface.
- * Undefined option arguments, use default mode = 0.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_moveFile_sync_007', 3, async function () {
- let dpath = await nextFileName('fileIO_test_moveFile_sync_007');
- let fpath = dpath + '/file_015.txt';
- let ddpath = dpath + '/dir_015';
- let ffpath = ddpath + '/file_015.txt';
- fileIO.mkdirSync(dpath);
- fileIO.mkdirSync(ddpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.moveFileSync(fpath, ffpath, undefined);
- let stat = fileIO.statSync(ffpath);
- expect(stat.size == FILE_CONTENT.length).assertTrue();
- fileIO.rmdirSync(dpath);
- } catch (e) {
- console.log('fileIO_test_moveFile_sync_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MOVEFILE_ASYNC_0000
- * @tc.name fileIO_test_moveFile_async_000
- * @tc.desc Test moveFile() interface. Promise.
- * Move a single file, shall work properly in normal case.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_moveFile_async_000', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_moveFile_async_000');
- let fpath = dpath + '/file_005.txt';
- let ddpath = dpath + '/dir_005';
- let ffpath = ddpath + '/file_005.txt';
- fileIO.mkdirSync(dpath);
- fileIO.mkdirSync(ddpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- await fileIO.moveFile(fpath, ffpath);
- let stat = fileIO.statSync(ffpath);
- expect(stat.size == FILE_CONTENT.length).assertTrue();
- fileIO.rmdirSync(dpath);
- done();
- } catch (e) {
- console.log('fileIO_test_moveFile_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
-/**
- * @tc.number SUB_DF_FILEIO_MOVEFILE_ASYNC_0100
- * @tc.name fileIO_test_moveFile_async_001
- * @tc.desc Test moveFile() interface. Callback.
- * Move a single file, shall work properly in normal case.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_moveFile_async_001', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_moveFile_async_001');
- let fpath = dpath + '/file_006.txt';
- let ddpath = dpath + '/dir_006';
- let ffpath = ddpath + '/file_006.txt';
- fileIO.mkdirSync(dpath);
- fileIO.mkdirSync(ddpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.moveFile(fpath, ffpath, (err) => {
- if (err) {
- console.log('fileIO_test_moveFile_async_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- let stat = fileIO.statSync(ffpath);
- expect(stat.size == FILE_CONTENT.length).assertTrue();
- fileIO.rmdirSync(dpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_moveFile_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MOVEFILE_ASYNC_0200
- * @tc.name fileIO_test_moveFile_async_002
- * @tc.desc Test moveFile() interface. Promise.
- * A file with the same name already exists under the destination path.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_moveFile_async_002', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_moveFile_async_002');
- let fpath = dpath + '/file_007.txt';
- let ddpath = dpath + '/dir_007';
- let ffpath = ddpath + '/file_007.txt';
- fileIO.mkdirSync(dpath);
- fileIO.mkdirSync(ddpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.copyFileSync(fpath, ffpath);
- await fileIO.moveFile(fpath, ffpath, 1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.rmdirSync(dpath);
- console.log('fileIO_test_moveFile_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900015 && e.message == 'File exists').assertTrue();
- done();
- }
- });
-
-/**
- * @tc.number SUB_DF_FILEIO_MOVEFILE_ASYNC_0300
- * @tc.name fileIO_test_moveFile_async_003
- * @tc.desc Test moveFile() interface. Callback.
- * A file with the same name already exists under the destination path.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_moveFile_async_003', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_moveFile_async_003');
- let fpath = dpath + '/file_008.txt';
- let ddpath = dpath + '/dir_008';
- let ffpath = ddpath + '/file_008.txt';
- fileIO.mkdirSync(dpath);
- fileIO.mkdirSync(ddpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.copyFileSync(fpath, ffpath);
- fileIO.moveFile(fpath, ffpath, 1, (err) => {
- if (err) {
- fileIO.rmdirSync(dpath);
- console.log('fileIO_test_moveFile_async_003 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900015 && err.message == 'File exists').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('fileIO_test_moveFile_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MOVEFILE_ASYNC_0400
- * @tc.name fileIO_test_moveFile_async_004
- * @tc.desc Test moveFile() interface. Promise.
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_moveFile_async_004', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_moveFile_async_004');
- let fpath = dpath + '/file_009.txt';
- let ddpath = dpath + '/dir_009';
- let ffpath = ddpath + '/file_009.txt';
- fileIO.mkdirSync(dpath);
- fileIO.mkdirSync(ddpath);
-
- try {
- await fileIO.moveFile(fpath, ffpath);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.rmdirSync(dpath);
- console.log('fileIO_test_moveFile_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MOVEFILE_ASYNC_0500
- * @tc.name fileIO_test_moveFile_async_005
- * @tc.desc Test moveFile() interface. Callback.
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_moveFile_async_005', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_moveFile_async_005');
- let fpath = dpath + '/file_010.txt';
- let ddpath = dpath + '/dir_010';
- let ffpath = ddpath + '/file_010.txt';
- fileIO.mkdirSync(dpath);
- fileIO.mkdirSync(ddpath);
-
- try {
- fileIO.moveFile(fpath, ffpath, (err) => {
- if (err) {
- fileIO.rmdirSync(dpath);
- console.log('fileIO_test_moveFile_async_005 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('fileIO_test_moveFile_async_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MOVEFILE_ASYNC_0600
- * @tc.name fileIO_test_moveFile_async_006
- * @tc.desc Test moveFile() interface. Promise.
- * The path point to a directory, not a file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_moveFile_async_006', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_moveFile_async_006');
- let ddpath = dpath + '/dir_011';
- fileIO.mkdirSync(dpath);
-
- try {
- await fileIO.moveFile(dpath, ddpath);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.rmdirSync(dpath);
- console.log('fileIO_test_moveFile_async_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MOVEFILE_ASYNC_0700
- * @tc.name fileIO_test_moveFile_async_007
- * @tc.desc Test moveFile() interface. Callback.
- * The path point to a directory, not a file.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_moveFile_async_007', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_moveFile_async_007');
- let ddpath = dpath + '/dir_012';
- fileIO.mkdirSync(dpath);
-
- try {
- fileIO.moveFile(dpath, ddpath, (err) => {
- if (err) {
- console.log('fileIO_test_moveFile_async_007 error package: ' + JSON.stringify(err));
- }
- expect(false).assertTrue();
- });
- } catch (e) {
- fileIO.rmdirSync(dpath);
- console.log('fileIO_test_moveFile_async_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MOVEFILE_ASYNC_0800
- * @tc.name fileIO_test_moveFile_async_008
- * @tc.desc Test moveFile() interface. Promise.
- * Missing parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_moveFile_async_008', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_moveFile_async_008');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- await fileIO.moveFile(fpath);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_moveFile_async_008 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MOVEFILE_ASYNC_0900
- * @tc.name fileIO_test_moveFile_async_009
- * @tc.desc Test moveFile() interface. Promise.
- * Entry parameters increase forced movement when mode = 0.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_moveFile_async_009', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_moveFile_async_009');
- let fpath = dpath + '/file_013.txt';
- let ddpath = dpath + '/dir_013';
- let ffpath = ddpath + '/file_013.txt';
- fileIO.mkdirSync(dpath);
- fileIO.mkdirSync(ddpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- expect(prepareFile(ffpath, '')).assertTrue();
-
- try {
- await fileIO.moveFile(fpath, ffpath, 0);
- let stat = fileIO.statSync(ffpath);
- expect(stat.size == FILE_CONTENT.length).assertTrue();
- fileIO.rmdirSync(dpath);
- done();
- } catch (e) {
- console.log('fileIO_test_moveFile_async_009 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MOVEFILE_ASYNC_1000
- * @tc.name fileIO_test_moveFile_async_010
- * @tc.desc Test moveFile() interface. Callback.
- * Entry parameters increase forced movement when mode = 0.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_moveFile_async_010', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_moveFile_async_010');
- let fpath = dpath + '/file_014.txt';
- let ddpath = dpath + '/dir_014';
- let ffpath = ddpath + '/file_014.txt';
- fileIO.mkdirSync(dpath);
- fileIO.mkdirSync(ddpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- expect(prepareFile(ffpath, '')).assertTrue();
-
- try {
- fileIO.moveFile(fpath, ffpath, 0, (err) => {
- if (err) {
- console.log('fileIO_test_moveFile_async_010 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- let stat = fileIO.statSync(ffpath);
- expect(stat.size == FILE_CONTENT.length).assertTrue();
- fileIO.rmdirSync(dpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_moveFile_async_010 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MOVEFILE_ASYNC_1100
- * @tc.name fileIO_test_moveFile_async_011
- * @tc.desc Test moveFile() interface. Promise.
- * Undefined option arguments, use default mode = 0.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_moveFile_async_011', 3, async function (done) {
- let dpath = await nextFileName('fileIO_test_moveFile_async_011');
- let fpath = dpath + '/file_016.txt';
- let ddpath = dpath + '/dir_016';
- let ffpath = ddpath + '/file_016.txt';
- fileIO.mkdirSync(dpath);
- fileIO.mkdirSync(ddpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- expect(prepareFile(ffpath, '')).assertTrue();
-
- try {
- await fileIO.moveFile(fpath, ffpath, undefined);
- let stat = fileIO.statSync(ffpath);
- expect(stat.size == FILE_CONTENT.length).assertTrue();
- fileIO.rmdirSync(dpath);
- done();
- } catch (e) {
- console.log('fileIO_test_moveFile_async_011 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_MOVEFILE_ASYNC_1200
- * @tc.name fileIO_test_moveFile_async_012
- * @tc.desc Test moveFile() interface. Callback.
- * Undefined option arguments, use default mode = 0.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_moveFile_async_012', 3, async function (done) {
- let dpath = await nextFileName('fileIO_test_moveFile_async_012');
- let fpath = dpath + '/file_017.txt';
- let ddpath = dpath + '/dir_017';
- let ffpath = ddpath + '/file_017.txt';
- fileIO.mkdirSync(dpath);
- fileIO.mkdirSync(ddpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- expect(prepareFile(ffpath, '')).assertTrue();
-
- try {
- fileIO.moveFile(fpath, ffpath, undefined, (err) => {
- if (err) {
- console.log('fileIO_test_moveFile_async_012 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- let stat = fileIO.statSync(ffpath);
- expect(stat.size == FILE_CONTENT.length).assertTrue();
- fileIO.rmdirSync(dpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_moveFile_async_012 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-});
+/*
+ * Copyright (C) 2023 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import {
+ fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect,
+} from '../Common';
+
+export default function fileIOMoveFile() {
+ describe('fileIO_fs_moveFile', function () {
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MOVEFILE_SYNC_0000
+ * @tc.name fileIO_test_moveFile_sync_000
+ * @tc.desc Test moveFileSync() interface.
+ * Move a single file, shall work properly in normal case.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_moveFile_sync_000', 0, async function () {
+ let dpath = await nextFileName('fileIO_test_moveFile_sync_000');
+ let fpath = dpath + '/file_000.txt';
+ let ddpath = dpath + '/dir_000';
+ let ffpath = ddpath + '/file_000.txt';
+ fileIO.mkdirSync(dpath);
+ fileIO.mkdirSync(ddpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.moveFileSync(fpath, ffpath);
+ let stat = fileIO.statSync(ffpath);
+ expect(stat.size == FILE_CONTENT.length).assertTrue();
+ fileIO.rmdirSync(dpath);
+ } catch (e) {
+ console.log('fileIO_test_moveFile_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MOVEFILE_SYNC_0100
+ * @tc.name fileIO_test_moveFile_sync_001
+ * @tc.desc Test moveFileSync() interface.
+ * A file with the same name already exists under the destination path.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_moveFile_sync_001', 0, async function () {
+ let dpath = await nextFileName('fileIO_test_moveFile_sync_001');
+ let fpath = dpath + '/file_001.txt';
+ let ddpath = dpath + '/dir_001';
+ let ffpath = ddpath + '/file_001.txt';
+ fileIO.mkdirSync(dpath);
+ fileIO.mkdirSync(ddpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.copyFileSync(fpath, ffpath);
+ fileIO.moveFileSync(fpath, ffpath, 1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.rmdirSync(dpath);
+ console.log('fileIO_test_moveFile_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900015 && e.message == 'File exists').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MOVEFILE_SYNC_0200
+ * @tc.name fileIO_test_moveFile_sync_002
+ * @tc.desc Test moveFileSync() interface.
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_moveFile_sync_002', 0, async function () {
+ let dpath = await nextFileName('fileIO_test_moveFile_sync_002');
+ let fpath = dpath + '/file_002.txt';
+ let ddpath = dpath + '/dir_002';
+ let ffpath = ddpath + '/file_002.txt';
+ fileIO.mkdirSync(dpath);
+ fileIO.mkdirSync(ddpath);
+
+ try {
+ fileIO.moveFileSync(fpath, ffpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.rmdirSync(dpath);
+ console.log('fileIO_test_moveFile_sync_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MOVEFILE_SYNC_0400
+ * @tc.name fileIO_test_moveFile_sync_004
+ * @tc.desc Test moveFileSync() interface.
+ * The path point to a directory, not a file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_moveFile_sync_004', 0, async function () {
+ let dpath = await nextFileName('fileIO_test_moveFile_sync_004');
+ let ddpath = dpath + '/dir_003';
+ fileIO.mkdirSync(dpath);
+
+ try {
+ fileIO.moveFileSync(dpath, ddpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.rmdirSync(dpath);
+ console.log('fileIO_test_moveFile_sync_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MOVEFILE_SYNC_0500
+ * @tc.name fileIO_test_moveFile_sync_005
+ * @tc.desc Test moveFileSync() interface.
+ * Missing parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_moveFile_sync_005', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_moveFile_sync_005');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.moveFileSync(fpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_moveFile_sync_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MOVEFILE_SYNC_0600
+ * @tc.name fileIO_test_moveFile_sync_006
+ * @tc.desc Test moveFileSync() interface.
+ * Entry parameters increase forced movement when mode = 0.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_moveFile_sync_006', 0, async function () {
+ let dpath = await nextFileName('fileIO_test_moveFile_sync_006');
+ let fpath = dpath + '/file_004.txt';
+ let ddpath = dpath + '/dir_004';
+ let ffpath = ddpath + '/file_004.txt';
+ fileIO.mkdirSync(dpath);
+ fileIO.mkdirSync(ddpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ expect(prepareFile(ffpath, '')).assertTrue();
+
+ try {
+ fileIO.moveFileSync(fpath, ffpath, 0);
+ let stat = fileIO.statSync(ffpath);
+ expect(stat.size == FILE_CONTENT.length).assertTrue();
+ fileIO.rmdirSync(dpath);
+ } catch (e) {
+ console.log('fileIO_test_moveFile_sync_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MOVEFILE_SYNC_0700
+ * @tc.name fileIO_test_moveFile_sync_007
+ * @tc.desc Test moveFileSync() interface.
+ * Undefined option arguments, use default mode = 0.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_moveFile_sync_007', 3, async function () {
+ let dpath = await nextFileName('fileIO_test_moveFile_sync_007');
+ let fpath = dpath + '/file_015.txt';
+ let ddpath = dpath + '/dir_015';
+ let ffpath = ddpath + '/file_015.txt';
+ fileIO.mkdirSync(dpath);
+ fileIO.mkdirSync(ddpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.moveFileSync(fpath, ffpath, undefined);
+ let stat = fileIO.statSync(ffpath);
+ expect(stat.size == FILE_CONTENT.length).assertTrue();
+ fileIO.rmdirSync(dpath);
+ } catch (e) {
+ console.log('fileIO_test_moveFile_sync_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MOVEFILE_ASYNC_0000
+ * @tc.name fileIO_test_moveFile_async_000
+ * @tc.desc Test moveFile() interface. Promise.
+ * Move a single file, shall work properly in normal case.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_moveFile_async_000', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_moveFile_async_000');
+ let fpath = dpath + '/file_005.txt';
+ let ddpath = dpath + '/dir_005';
+ let ffpath = ddpath + '/file_005.txt';
+ fileIO.mkdirSync(dpath);
+ fileIO.mkdirSync(ddpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ await fileIO.moveFile(fpath, ffpath);
+ let stat = fileIO.statSync(ffpath);
+ expect(stat.size == FILE_CONTENT.length).assertTrue();
+ fileIO.rmdirSync(dpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_moveFile_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+/**
+ * @tc.number SUB_DF_FILEIO_MOVEFILE_ASYNC_0100
+ * @tc.name fileIO_test_moveFile_async_001
+ * @tc.desc Test moveFile() interface. Callback.
+ * Move a single file, shall work properly in normal case.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_moveFile_async_001', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_moveFile_async_001');
+ let fpath = dpath + '/file_006.txt';
+ let ddpath = dpath + '/dir_006';
+ let ffpath = ddpath + '/file_006.txt';
+ fileIO.mkdirSync(dpath);
+ fileIO.mkdirSync(ddpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.moveFile(fpath, ffpath, (err) => {
+ if (err) {
+ console.log('fileIO_test_moveFile_async_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ let stat = fileIO.statSync(ffpath);
+ expect(stat.size == FILE_CONTENT.length).assertTrue();
+ fileIO.rmdirSync(dpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_moveFile_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MOVEFILE_ASYNC_0200
+ * @tc.name fileIO_test_moveFile_async_002
+ * @tc.desc Test moveFile() interface. Promise.
+ * A file with the same name already exists under the destination path.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_moveFile_async_002', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_moveFile_async_002');
+ let fpath = dpath + '/file_007.txt';
+ let ddpath = dpath + '/dir_007';
+ let ffpath = ddpath + '/file_007.txt';
+ fileIO.mkdirSync(dpath);
+ fileIO.mkdirSync(ddpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.copyFileSync(fpath, ffpath);
+ await fileIO.moveFile(fpath, ffpath, 1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.rmdirSync(dpath);
+ console.log('fileIO_test_moveFile_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900015 && e.message == 'File exists').assertTrue();
+ done();
+ }
+ });
+
+/**
+ * @tc.number SUB_DF_FILEIO_MOVEFILE_ASYNC_0300
+ * @tc.name fileIO_test_moveFile_async_003
+ * @tc.desc Test moveFile() interface. Callback.
+ * A file with the same name already exists under the destination path.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_moveFile_async_003', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_moveFile_async_003');
+ let fpath = dpath + '/file_008.txt';
+ let ddpath = dpath + '/dir_008';
+ let ffpath = ddpath + '/file_008.txt';
+ fileIO.mkdirSync(dpath);
+ fileIO.mkdirSync(ddpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.copyFileSync(fpath, ffpath);
+ fileIO.moveFile(fpath, ffpath, 1, (err) => {
+ if (err) {
+ fileIO.rmdirSync(dpath);
+ console.log('fileIO_test_moveFile_async_003 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900015 && err.message == 'File exists').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('fileIO_test_moveFile_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MOVEFILE_ASYNC_0400
+ * @tc.name fileIO_test_moveFile_async_004
+ * @tc.desc Test moveFile() interface. Promise.
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_moveFile_async_004', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_moveFile_async_004');
+ let fpath = dpath + '/file_009.txt';
+ let ddpath = dpath + '/dir_009';
+ let ffpath = ddpath + '/file_009.txt';
+ fileIO.mkdirSync(dpath);
+ fileIO.mkdirSync(ddpath);
+
+ try {
+ await fileIO.moveFile(fpath, ffpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.rmdirSync(dpath);
+ console.log('fileIO_test_moveFile_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MOVEFILE_ASYNC_0500
+ * @tc.name fileIO_test_moveFile_async_005
+ * @tc.desc Test moveFile() interface. Callback.
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_moveFile_async_005', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_moveFile_async_005');
+ let fpath = dpath + '/file_010.txt';
+ let ddpath = dpath + '/dir_010';
+ let ffpath = ddpath + '/file_010.txt';
+ fileIO.mkdirSync(dpath);
+ fileIO.mkdirSync(ddpath);
+
+ try {
+ fileIO.moveFile(fpath, ffpath, (err) => {
+ if (err) {
+ fileIO.rmdirSync(dpath);
+ console.log('fileIO_test_moveFile_async_005 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('fileIO_test_moveFile_async_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MOVEFILE_ASYNC_0600
+ * @tc.name fileIO_test_moveFile_async_006
+ * @tc.desc Test moveFile() interface. Promise.
+ * The path point to a directory, not a file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_moveFile_async_006', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_moveFile_async_006');
+ let ddpath = dpath + '/dir_011';
+ fileIO.mkdirSync(dpath);
+
+ try {
+ await fileIO.moveFile(dpath, ddpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.rmdirSync(dpath);
+ console.log('fileIO_test_moveFile_async_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MOVEFILE_ASYNC_0700
+ * @tc.name fileIO_test_moveFile_async_007
+ * @tc.desc Test moveFile() interface. Callback.
+ * The path point to a directory, not a file.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_moveFile_async_007', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_moveFile_async_007');
+ let ddpath = dpath + '/dir_012';
+ fileIO.mkdirSync(dpath);
+
+ try {
+ fileIO.moveFile(dpath, ddpath, (err) => {
+ if (err) {
+ console.log('fileIO_test_moveFile_async_007 error package: ' + JSON.stringify(err));
+ }
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ fileIO.rmdirSync(dpath);
+ console.log('fileIO_test_moveFile_async_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MOVEFILE_ASYNC_0800
+ * @tc.name fileIO_test_moveFile_async_008
+ * @tc.desc Test moveFile() interface. Promise.
+ * Missing parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_moveFile_async_008', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_moveFile_async_008');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ await fileIO.moveFile(fpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_moveFile_async_008 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MOVEFILE_ASYNC_0900
+ * @tc.name fileIO_test_moveFile_async_009
+ * @tc.desc Test moveFile() interface. Promise.
+ * Entry parameters increase forced movement when mode = 0.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_moveFile_async_009', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_moveFile_async_009');
+ let fpath = dpath + '/file_013.txt';
+ let ddpath = dpath + '/dir_013';
+ let ffpath = ddpath + '/file_013.txt';
+ fileIO.mkdirSync(dpath);
+ fileIO.mkdirSync(ddpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ expect(prepareFile(ffpath, '')).assertTrue();
+
+ try {
+ await fileIO.moveFile(fpath, ffpath, 0);
+ let stat = fileIO.statSync(ffpath);
+ expect(stat.size == FILE_CONTENT.length).assertTrue();
+ fileIO.rmdirSync(dpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_moveFile_async_009 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MOVEFILE_ASYNC_1000
+ * @tc.name fileIO_test_moveFile_async_010
+ * @tc.desc Test moveFile() interface. Callback.
+ * Entry parameters increase forced movement when mode = 0.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_moveFile_async_010', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_moveFile_async_010');
+ let fpath = dpath + '/file_014.txt';
+ let ddpath = dpath + '/dir_014';
+ let ffpath = ddpath + '/file_014.txt';
+ fileIO.mkdirSync(dpath);
+ fileIO.mkdirSync(ddpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ expect(prepareFile(ffpath, '')).assertTrue();
+
+ try {
+ fileIO.moveFile(fpath, ffpath, 0, (err) => {
+ if (err) {
+ console.log('fileIO_test_moveFile_async_010 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ let stat = fileIO.statSync(ffpath);
+ expect(stat.size == FILE_CONTENT.length).assertTrue();
+ fileIO.rmdirSync(dpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_moveFile_async_010 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MOVEFILE_ASYNC_1100
+ * @tc.name fileIO_test_moveFile_async_011
+ * @tc.desc Test moveFile() interface. Promise.
+ * Undefined option arguments, use default mode = 0.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_moveFile_async_011', 3, async function (done) {
+ let dpath = await nextFileName('fileIO_test_moveFile_async_011');
+ let fpath = dpath + '/file_016.txt';
+ let ddpath = dpath + '/dir_016';
+ let ffpath = ddpath + '/file_016.txt';
+ fileIO.mkdirSync(dpath);
+ fileIO.mkdirSync(ddpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ expect(prepareFile(ffpath, '')).assertTrue();
+
+ try {
+ await fileIO.moveFile(fpath, ffpath, undefined);
+ let stat = fileIO.statSync(ffpath);
+ expect(stat.size == FILE_CONTENT.length).assertTrue();
+ fileIO.rmdirSync(dpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_moveFile_async_011 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_MOVEFILE_ASYNC_1200
+ * @tc.name fileIO_test_moveFile_async_012
+ * @tc.desc Test moveFile() interface. Callback.
+ * Undefined option arguments, use default mode = 0.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_moveFile_async_012', 3, async function (done) {
+ let dpath = await nextFileName('fileIO_test_moveFile_async_012');
+ let fpath = dpath + '/file_017.txt';
+ let ddpath = dpath + '/dir_017';
+ let ffpath = ddpath + '/file_017.txt';
+ fileIO.mkdirSync(dpath);
+ fileIO.mkdirSync(ddpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ expect(prepareFile(ffpath, '')).assertTrue();
+
+ try {
+ fileIO.moveFile(fpath, ffpath, undefined, (err) => {
+ if (err) {
+ console.log('fileIO_test_moveFile_async_012 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ let stat = fileIO.statSync(ffpath);
+ expect(stat.size == FILE_CONTENT.length).assertTrue();
+ fileIO.rmdirSync(dpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_moveFile_async_012 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+});
}
\ No newline at end of file
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/open.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/open.test.js
similarity index 97%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/open.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/open.test.js
index 2bcd16725f265bc93ef0cb51a8e255bd138fd94b..ddc608c7b123b25a19db4d33ec11b16d01a2b82e 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/open.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/members/open.test.js
@@ -1,1401 +1,1401 @@
-/*
- * Copyright (C) 2022 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the 'License');
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an 'AS IS' BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import {
- fileIO, FILE_CONTENT, prepareFile, nextFileName, isIntNum, describe, it, expect,
-} from '../Common';
-
-export default function fileIOOpen() {
- describe('fileIO_fs_open', function () {
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_SYNC_0000
- * @tc.name fileIO_test_open_sync_000
- * @tc.desc Test openSync() interfaces. mode=0o0.
- * Open the file in read-only mode, verifying the file is readable.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_open_sync_000', 0, async function () {
- let fpath = await nextFileName('fileIO_test_open_sync_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let readlen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
- expect(readlen == FILE_CONTENT.length).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_open_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_SYNC_0100
- * @tc.name fileIO_test_open_sync_001
- * @tc.desc Test openSync() interfaces. mode=0o1.
- * Open the file in write-only mode, verifying the file is writable.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_sync_001', 0, async function () {
- let fpath = await nextFileName('fileIO_test_open_sync_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let bytesWritten = fileIO.writeSync(file.fd, FILE_CONTENT);
- expect(bytesWritten == FILE_CONTENT.length).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_open_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_SYNC_0200
- * @tc.name fileIO_test_open_sync_002
- * @tc.desc Test openSync() interfaces. mode=0o2.
- * Open the file in read-write mode, verifying the file is readable and writable.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_sync_002', 0, async function () {
- let fpath = await nextFileName('fileIO_test_open_sync_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- let readlen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
- expect(readlen == FILE_CONTENT.length).assertTrue();
- let length = 20;
- let bytesWritten = fileIO.writeSync(file.fd, new ArrayBuffer(length), { offset: 0 });
- expect(bytesWritten == length).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_open_sync_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_SYNC_0300
- * @tc.name fileIO_test_open_sync_003
- * @tc.desc Test openSync() interfaces. Missing parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_sync_003', 0, function () {
- try {
- fileIO.openSync();
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_open_sync_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_SYNC_0400
- * @tc.name fileIO_test_open_sync_004
- * @tc.desc Test openSync() interfaces. mode=0o102.
- * If the path point to the file which does not exist, the file can be created.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_sync_004', 0, async function () {
- let fpath = await nextFileName('fileIO_test_open_sync_004');
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.CREATE | fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_open_sync_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_SYNC_0500
- * @tc.name fileIO_test_open_sync_005
- * @tc.desc Test openSync() interfaces. mode=0o1002.
- * If the file exists and the file is opened for read-write, trim its length to zero.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_sync_005', 0, async function () {
- let fpath = await nextFileName('fileIO_test_open_sync_005');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.TRUNC | fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
- expect(readLen == 0).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_open_sync_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_SYNC_0600
- * @tc.name fileIO_test_open_sync_006
- * @tc.desc Test openSync() interfaces. mode=0o2002.
- * Open as append, subsequent writes will append to the end of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_sync_006', 0, async function () {
- let fpath = await nextFileName('fileIO_test_open_sync_006');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.APPEND | fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- let length = 100;
- let bytesWritten = fileIO.writeSync(file.fd, new ArrayBuffer(length));
- expect(bytesWritten == length).assertTrue();
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), { offset: 0 });
- expect(readLen == length + FILE_CONTENT.length).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_open_sync_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_SYNC_0700
- * @tc.name fileIO_test_open_sync_007
- * @tc.desc Test openSync() interfaces. mode=0o4002.
- * If the file is a special file, the opening and subsequent IOs perform non-blocking operations.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_sync_007', 0, async function () {
- let fpath = await nextFileName('fileIO_test_open_sync_007');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.NONBLOCK | fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_open_sync_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_SYNC_0800
- * @tc.name fileIO_test_open_sync_008
- * @tc.desc Test openSync() interfaces. mode=0o200000.
- * The path points to a directory.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_sync_008', 0, async function () {
- let dpath = await nextFileName('fileIO_test_open_sync_008');
- fileIO.mkdirSync(dpath);
-
- try {
- let file = fileIO.openSync(dpath, fileIO.OpenMode.DIR);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.rmdirSync(dpath);
- } catch (e) {
- console.log('fileIO_test_open_sync_008 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_SYNC_0900
- * @tc.name fileIO_test_open_sync_009
- * @tc.desc Test openSync() interfaces. mode=0o200000.
- * The path does not a directory, throw error.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_sync_009', 0, async function () {
- let fpath = await nextFileName('fileIO_test_open_sync_009');
- expect(prepareFile(fpath, '')).assertTrue();
-
- try {
- fileIO.openSync(fpath, fileIO.OpenMode.DIR);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_open_sync_009 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900018 && e.message == 'Not a directory').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_SYNC_1000
- * @tc.name fileIO_test_open_sync_010
- * @tc.desc Test openSync() interfaces. mode=0o400002.
- * The path does not point to a symbolic link.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_sync_010', 0, async function () {
- let fpath = await nextFileName('fileIO_test_open_sync_010');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.NOFOLLOW | fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_open_sync_010 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_SYNC_1100
- * @tc.name fileIO_test_open_sync_011
- * @tc.desc Test openSync() interfaces. mode=0o400002.
- * The path points to a symbolic link, throw error.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_sync_011', 0, async function () {
- let fpath = await nextFileName('fileIO_test_open_sync_011');
- let ffpath = fpath + 'aaaa';
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.symlinkSync(fpath, ffpath);
- fileIO.openSync(ffpath, fileIO.OpenMode.NOFOLLOW | fileIO.OpenMode.READ_WRITE);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- fileIO.unlinkSync(ffpath);
- console.log('fileIO_test_open_sync_011 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900033 && e.message == 'Too many symbolic links encountered').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_SYNC_1200
- * @tc.name fileIO_test_open_sync_012
- * @tc.desc Test openSync() interfaces. mode=0o4010002.
- * Open the file in the way of synchronous IO.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_sync_012', 0, async function () {
- let fpath = await nextFileName('fileIO_test_open_sync_012');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.SYNC | fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_open_sync_012 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_SYNC_1300
- * @tc.name fileIO_test_open_sync_013
- * @tc.desc Test openSync() interfaces. Invalid path.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_sync_013', 0, async function () {
-
- try {
- fileIO.openSync(-1, fileIO.OpenMode.READ_WRITE);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_open_sync_013 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_SYNC_1400
- * @tc.name fileIO_test_open_sync_014
- * @tc.desc Test openSync() interfaces. mode=0o200000.
- * The path refers to a directory, not a file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_sync_014', 0, async function () {
- let dpath = await nextFileName('fileIO_test_open_sync_012');
- fileIO.mkdirSync(dpath);
-
- try {
- fileIO.openSync(dpath, fileIO.OpenMode.READ_WRITE);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.rmdirSync(dpath);
- console.log('fileIO_test_open_sync_014 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900019 && e.message == 'Is a directory').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_SYNC_1500
- * @tc.name fileIO_test_open_sync_015
- * @tc.desc Test openSync() interfaces.
- * Undefined option arguments, use default mode = 0o0.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_sync_015', 3, async function () {
- let fpath = await nextFileName('fileIO_test_open_sync_015');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file;
-
- try {
- file = fileIO.openSync(fpath, undefined);
- expect(isIntNum(file.fd)).assertTrue();
- let readlen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
- expect(readlen == FILE_CONTENT.length).assertTrue();
- fileIO.writeSync(file.fd, new ArrayBuffer(4096));
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_open_sync_015 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900008 && e.message == 'Bad file descriptor').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_0000
- * @tc.name fileIO_test_open_async_000
- * @tc.desc Test open() interfaces. mode=0o0. Promise.
- * Open the file in read-only mode, verifying the file is readable.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_open_async_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_open_async_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = await fileIO.open(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.read(file.fd, new ArrayBuffer(4096))
- .then((readLen) => {
- expect(readLen == FILE_CONTENT.length).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_open_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_0100
- * @tc.name fileIO_test_open_async_001
- * @tc.desc Test open() interfaces. mode=0o0. Callback.
- * Open the file in read-only mode, verifying the file is readable.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_open_async_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.open(fpath, fileIO.OpenMode.READ_ONLY, (err, file) => {
- if(err) {
- console.log('fileIO_test_open_async_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.read(file.fd, new ArrayBuffer(4096))
- .then((readLen) => {
- expect(readLen == FILE_CONTENT.length).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- });
- } catch (e) {
- console.log('fileIO_test_open_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_0200
- * @tc.name fileIO_test_open_async_002
- * @tc.desc Test open() interfaces. mode=0o1. Promise.
- * Open the file in write-only mode, verifying the file is writable.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_002', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_open_async_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let length = 20;
-
- try {
- let file = await fileIO.open(fpath, fileIO.OpenMode.WRITE_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.write(file.fd, new ArrayBuffer(length))
- .then((bytesWritten) => {
- expect(bytesWritten == length).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_open_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_0300
- * @tc.name fileIO_test_open_async_003
- * @tc.desc Test open() interfaces. mode=0o1. Callback.
- * Open the file in write-only mode, verifying the file is writable.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_003', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_open_async_003');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let length = 20;
-
- try {
- fileIO.open(fpath, fileIO.OpenMode.WRITE_ONLY, (err, file) => {
- if(err) {
- console.log('fileIO_test_open_async_003 error package' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.write(file.fd, new ArrayBuffer(length))
- .then((bytesWritten) => {
- expect(bytesWritten == length).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- });
- });
- done();
- } catch (e) {
- console.log('fileIO_test_open_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_0400
- * @tc.name fileIO_test_open_async_004
- * @tc.desc Test open() interfaces. mode=0o2. Promise.
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_004', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_open_async_004');
-
- try {
- await fileIO.open(fpath, fileIO.OpenMode.READ_WRITE);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_open_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_0500
- * @tc.name fileIO_test_open_async_005
- * @tc.desc Test open() interfaces. mode=0o2. Callback.
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_005', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_open_async_005');
-
- try {
- fileIO.open(fpath, fileIO.OpenMode.READ_WRITE, (err) => {
- if(err) {
- console.log('fileIO_test_open_async_005 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('fileIO_test_open_async_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_0600
- * @tc.name fileIO_test_open_async_006
- * @tc.desc Test open() interfaces. mode=0o2. Promise.then().catch()
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_006', 0, async function () {
- let fpath = await nextFileName('fileIO_test_open_async_006');
-
- try {
- fileIO.open(fpath, fileIO.OpenMode.READ_WRITE).then(() => {
- expect(false).assertTrue();
- }).catch((err) => {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_open_async_006 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
- });
- } catch (e) {
- console.log('fileIO_test_open_async_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_0700
- * @tc.name fileIO_test_open_async_007
- * @tc.desc Test open() interfaces. Promise.
- * Invalid path.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_007', 0, async function (done) {
-
- try {
- await fileIO.open(-1, fileIO.OpenMode.READ_WRITE);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_open_async_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_0800
- * @tc.name fileIO_test_open_async_008
- * @tc.desc Test open() interfaces. Callback.
- * Invalid path.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_008', 0, async function (done) {
-
- try {
- fileIO.open(-1, fileIO.OpenMode.READ_WRITE, (err) => {
- expect(false).assertTrue();
- });
- } catch (e) {
- console.log('fileIO_test_open_async_008 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_0900
- * @tc.name fileIO_test_open_async_009
- * @tc.desc Test open() interfaces. mode=0o102. Promise.
- * If the path point to the file which does not exist, the file can be created.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_009', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_open_async_009');
-
- try {
- let file = await fileIO.open(fpath, fileIO.OpenMode.CREATE | fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_open_async_009 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_1000
- * @tc.name fileIO_test_open_async_010
- * @tc.desc Test open() interfaces. mode=0o102. Callback.
- * If the path point to the file which does not exist, the file can be created.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_010', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_open_async_010');
-
- try {
- fileIO.open(fpath, fileIO.OpenMode.CREATE | fileIO.OpenMode.WRITE_ONLY, (err, file) => {
- if(err) {
- console.log('fileIO_test_open_async_010 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_open_async_010 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_1100
- * @tc.name fileIO_test_open_async_011
- * @tc.desc Test open() interfaces. mode=0o1002. Promise.
- * If the file exists and the file is opened for read-write, trim its length to zero.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_011', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_open_async_011');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = await fileIO.open(fpath, fileIO.OpenMode.TRUNC | fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.read(file.fd, new ArrayBuffer(4096))
- .then((readLen) => {
- expect(readLen == 0).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- });
- done();
- } catch (e) {
- console.log('fileIO_test_open_async_011 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_1200
- * @tc.name fileIO_test_open_async_012
- * @tc.desc Test open() interfaces. mode=0o1002. Callback.
- * If the file exists and the file is opened for read-write, trim its length to zero.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_012', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_open_async_012');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.open(fpath, fileIO.OpenMode.TRUNC | fileIO.OpenMode.READ_WRITE, (err, file) => {
- if(err) {
- console.log('fileIO_test_open_async_012 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.read(file.fd, new ArrayBuffer(4096))
- .then((readLen) => {
- expect(readLen == 0).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- });
- done();
- });
- } catch (e) {
- console.log('fileIO_test_open_async_012 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_1300
- * @tc.name fileIO_test_open_async_013
- * @tc.desc Test open() interfaces. mode=0o2002. Promise.
- * Open as append, subsequent writes will append to the end of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_013', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_open_async_013');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let length = 100;
-
- try {
- let file = await fileIO.open(fpath, fileIO.OpenMode.APPEND | fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.writeSync(file.fd, new ArrayBuffer(length));
- fileIO.read(file.fd, new ArrayBuffer(4096), { offset: 0 })
- .then((readLen) => {
- expect(readLen == length + FILE_CONTENT.length).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- });
- done();
- } catch (e) {
- console.log('fileIO_test_open_async_013 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_1400
- * @tc.name fileIO_test_open_async_014
- * @tc.desc Test open() interfaces. mode=0o2002. Callback.
- * Open as append, subsequent writes will append to the end of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_014', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_open_async_014');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let length = 100;
-
- try {
- fileIO.open(fpath, fileIO.OpenMode.APPEND | fileIO.OpenMode.READ_WRITE, (err, file) => {
- if(err) {
- console.log('fileIO_test_open_async_014 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.writeSync(file.fd, new ArrayBuffer(length));
- fileIO.read(file.fd, new ArrayBuffer(4096), { offset: 0 })
- .then((readLen) => {
- expect(readLen == length + FILE_CONTENT.length).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- });
- done();
- });
- } catch (e) {
- console.log('fileIO_test_open_async_014 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_1500
- * @tc.name fileIO_test_open_async_015
- * @tc.desc Test open() interfaces. mode=0o4002. Promise.
- * If the file is a special file, the opening and subsequent IOs perform non-blocking operations.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_015', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_open_async_015');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = await fileIO.open(fpath, fileIO.OpenMode.NONBLOCK | fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_open_async_015 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_1600
- * @tc.name fileIO_test_open_async_016
- * @tc.desc Test open() interfaces. mode=0o4002. Callback.
- * If the file is a special file, the opening and subsequent IOs perform non-blocking operations.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_016', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_open_async_016');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.open(fpath, fileIO.OpenMode.NONBLOCK | fileIO.OpenMode.READ_WRITE, (err, file) => {
- if(err) {
- console.log('fileIO_test_open_async_016 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_open_async_016 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_1700
- * @tc.name fileIO_test_open_async_017
- * @tc.desc Test open() interfaces. mode=0o200000. Promise.
- * The path points to a directory.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_017', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_open_async_017');
- fileIO.mkdirSync(dpath);
-
- try {
- let file = await fileIO.open(dpath, fileIO.OpenMode.DIR);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.rmdirSync(dpath);
- done();
- } catch (e) {
- console.log('fileIO_test_open_async_017 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_1800
- * @tc.name fileIO_test_open_async_018
- * @tc.desc Test open() interfaces. mode=0o200000. Callback.
- * The path points to a directory.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_018', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_open_async_018');
- fileIO.mkdirSync(dpath);
-
- try {
- fileIO.open(dpath, fileIO.OpenMode.DIR, (err, file) => {
- if(err) {
- console.log('fileIO_test_open_async_018 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.rmdirSync(dpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_open_async_018 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_1900
- * @tc.name fileIO_test_open_async_019
- * @tc.desc Test open() interfaces. mode=0o200000. Promise.
- * The path does not point to a directory, throw error.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_019', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_open_async_019');
- expect(prepareFile(fpath, '')).assertTrue();
-
- try {
- await fileIO.open(fpath, fileIO.OpenMode.DIR);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_open_async_019 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900018 && e.message == 'Not a directory').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_2000
- * @tc.name fileIO_test_open_async_020
- * @tc.desc Test open() interfaces. mode=0o200000. Callback.
- * The path does not point to a directory, throw error.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_020', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_open_async_020');
- expect(prepareFile(fpath, '')).assertTrue();
-
- try {
- fileIO.open(fpath, fileIO.OpenMode.DIR, (err) => {
- if(err) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_open_async_020 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900018 && err.message == 'Not a directory').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('fileIO_test_open_async_020 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_2100
- * @tc.name fileIO_test_open_async_021
- * @tc.desc Test open() interfaces. mode=0o200000. Promise.then().catch().
- * The path does not point to a directory, throw error.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_021', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_open_async_021');
- expect(prepareFile(fpath, '')).assertTrue();
-
- try {
- fileIO.open(fpath, fileIO.OpenMode.DIR).then(() => {
- expect(false).assertTrue();
- }).catch((err) => {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_open_async_021 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900018 && err.message == 'Not a directory').assertTrue();
- done();
- });
- } catch (e) {
- console.log('fileIO_test_open_async_021 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_2200
- * @tc.name fileIO_test_open_async_022
- * @tc.desc Test open() interfaces. mode=0o400002. Promise.
- * The path does not point to a symbolic link.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_022', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_open_async_022');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = await fileIO.open(fpath, fileIO.OpenMode.NOFOLLOW | fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_open_async_022 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_2300
- * @tc.name fileIO_test_open_async_023
- * @tc.desc Test open() interfaces. mode=0o400002. Callback.
- * The path does not point to a symbolic link.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_023', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_open_async_023');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.open(fpath, fileIO.OpenMode.NOFOLLOW | fileIO.OpenMode.READ_WRITE, (err, file) => {
- if(err) {
- console.log('fileIO_test_open_async_023 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_open_async_023 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_2400
- * @tc.name fileIO_test_open_async_024
- * @tc.desc Test open() interfaces. mode=0o400002. Promise.
- * The path point to a symbolic link, throw error.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_024', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_open_async_024');
- let ffpath = fpath + 'aaaa';
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.symlinkSync(fpath, ffpath);
- await fileIO.open(ffpath, fileIO.OpenMode.NOFOLLOW | fileIO.OpenMode.READ_WRITE);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- fileIO.unlinkSync(ffpath);
- console.log('fileIO_test_open_async_024 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900033 && e.message == 'Too many symbolic links encountered').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_2500
- * @tc.name fileIO_test_open_async_025
- * @tc.desc Test open() interfaces. mode=0o400002. Callback.
- * The path point to a symbolic link, throw error.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_025', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_open_async_025');
- let ffpath = fpath + 'link';
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.symlinkSync(fpath, ffpath);
- fileIO.open(ffpath, fileIO.OpenMode.NOFOLLOW | fileIO.OpenMode.READ_WRITE, (err) => {
- if(err) {
- console.log('fileIO_test_open_async_025 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900033 && err.message == 'Too many symbolic links encountered').assertTrue();
- }
- fileIO.unlinkSync(fpath);
- fileIO.unlinkSync(ffpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_open_async_025 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_2600
- * @tc.name fileIO_test_open_async_026
- * @tc.desc Test open() interfaces. mode=0o400002. Promise.then().catch()
- * The path point to a symbolic link, throw error.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_026', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_open_async_026');
- let ffpath = fpath + 'link';
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.symlinkSync(fpath, ffpath);
- fileIO.open(ffpath, fileIO.OpenMode.NOFOLLOW | fileIO.OpenMode.READ_WRITE).then(() => {
- expect(false).assertTrue();
- }).catch((err) => {
- console.log('fileIO_test_open_async_026 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900033 && err.message == 'Too many symbolic links encountered').assertTrue();
- fileIO.unlinkSync(fpath);
- fileIO.unlinkSync(ffpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_open_async_026 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_2700
- * @tc.name fileIO_test_open_async_027
- * @tc.desc Test open() interfaces. mode=0o4010002. Promise.
- * Open the file in the way of synchronous IO.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_027', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_open_async_027');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = await fileIO.open(fpath, fileIO.OpenMode.SYNC | fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_open_async_027 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_2800
- * @tc.name fileIO_test_open_async_028
- * @tc.desc Test open() interfaces. mode=0o4010002. Callback.
- * Open the file in the way of synchronous IO.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_028', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_open_async_028');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.open(fpath, fileIO.OpenMode.SYNC | fileIO.OpenMode.READ_WRITE, (err, file) => {
- if(err) {
- console.log('fileIO_test_open_async_028 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_open_async_028 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_2900
- * @tc.name fileIO_test_open_async_029
- * @tc.desc Test open() interfaces. Promise.
- * The path refers to a file, not a directory.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_029', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_open_async_029');
- fileIO.mkdirSync(dpath);
-
- try {
- await fileIO.open(dpath, fileIO.OpenMode.READ_WRITE);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.rmdirSync(dpath);
- console.log('fileIO_test_open_async_029 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900019 && e.message == 'Is a directory').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_3000
- * @tc.name fileIO_test_open_async_030
- * @tc.desc Test open() interfaces. Callback.
- * The path refers to a file, not a directory.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_030', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_open_async_030');
- fileIO.mkdirSync(dpath);
-
- try {
- fileIO.open(dpath, fileIO.OpenMode.READ_WRITE, (err, file) => {
- if (err) {
- fileIO.rmdirSync(dpath);
- console.log('fileIO_test_open_async_030 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900019 && err.message == 'Is a directory').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('fileIO_test_open_async_030 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_3100
- * @tc.name fileIO_test_open_async_031
- * @tc.desc Test open() interfaces. Promise.
- * Undefined option arguments, use default mode = 0o0.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_031', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_open_async_031');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file;
-
- try {
- file = await fileIO.open(fpath, undefined);
- expect(isIntNum(file.fd)).assertTrue();
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
- expect(readLen == FILE_CONTENT.length).assertTrue();
- fileIO.writeSync(file.fd, new ArrayBuffer(4096));
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_open_async_031 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900008 && e.message == 'Bad file descriptor').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_3200
- * @tc.name fileIO_test_open_async_032
- * @tc.desc Test open() interfaces. Callback.
- * Undefined option arguments, use default mode = 0o0.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_open_async_032', 3, async function (done) {
- let fpath = await nextFileName('fileIO_test_open_async_032');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.open(fpath, undefined, (err, file) => {
- if (err) {
- console.log('fileIO_test_open_async_032 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(file.fd)).assertTrue();
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
- expect(readLen == FILE_CONTENT.length).assertTrue();
- fileIO.write(file.fd, new ArrayBuffer(4096), (err, bytesWritten) => {
- if (err) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_open_async_032 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900008 && err.message == 'Bad file descriptor').assertTrue();
- done();
- } else {
- expect(false).assertTrue();
- }
- });
- });
- } catch (e) {
- console.log('fileIO_test_open_async_032 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-});
-}
+/*
+ * Copyright (C) 2022 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import {
+ fileIO, FILE_CONTENT, prepareFile, nextFileName, isIntNum, describe, it, expect,
+} from '../Common';
+
+export default function fileIOOpen() {
+ describe('fileIO_fs_open', function () {
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_SYNC_0000
+ * @tc.name fileIO_test_open_sync_000
+ * @tc.desc Test openSync() interfaces. mode=0o0.
+ * Open the file in read-only mode, verifying the file is readable.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_open_sync_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_open_sync_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readlen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
+ expect(readlen == FILE_CONTENT.length).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_open_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_SYNC_0100
+ * @tc.name fileIO_test_open_sync_001
+ * @tc.desc Test openSync() interfaces. mode=0o1.
+ * Open the file in write-only mode, verifying the file is writable.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_sync_001', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_open_sync_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let bytesWritten = fileIO.writeSync(file.fd, FILE_CONTENT);
+ expect(bytesWritten == FILE_CONTENT.length).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_open_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_SYNC_0200
+ * @tc.name fileIO_test_open_sync_002
+ * @tc.desc Test openSync() interfaces. mode=0o2.
+ * Open the file in read-write mode, verifying the file is readable and writable.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_sync_002', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_open_sync_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readlen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
+ expect(readlen == FILE_CONTENT.length).assertTrue();
+ let length = 20;
+ let bytesWritten = fileIO.writeSync(file.fd, new ArrayBuffer(length), { offset: 0 });
+ expect(bytesWritten == length).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_open_sync_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_SYNC_0300
+ * @tc.name fileIO_test_open_sync_003
+ * @tc.desc Test openSync() interfaces. Missing parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_sync_003', 0, function () {
+ try {
+ fileIO.openSync();
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_open_sync_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_SYNC_0400
+ * @tc.name fileIO_test_open_sync_004
+ * @tc.desc Test openSync() interfaces. mode=0o102.
+ * If the path point to the file which does not exist, the file can be created.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_sync_004', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_open_sync_004');
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.CREATE | fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_open_sync_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_SYNC_0500
+ * @tc.name fileIO_test_open_sync_005
+ * @tc.desc Test openSync() interfaces. mode=0o1002.
+ * If the file exists and the file is opened for read-write, trim its length to zero.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_sync_005', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_open_sync_005');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.TRUNC | fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
+ expect(readLen == 0).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_open_sync_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_SYNC_0600
+ * @tc.name fileIO_test_open_sync_006
+ * @tc.desc Test openSync() interfaces. mode=0o2002.
+ * Open as append, subsequent writes will append to the end of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_sync_006', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_open_sync_006');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.APPEND | fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ let length = 100;
+ let bytesWritten = fileIO.writeSync(file.fd, new ArrayBuffer(length));
+ expect(bytesWritten == length).assertTrue();
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), { offset: 0 });
+ expect(readLen == length + FILE_CONTENT.length).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_open_sync_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_SYNC_0700
+ * @tc.name fileIO_test_open_sync_007
+ * @tc.desc Test openSync() interfaces. mode=0o4002.
+ * If the file is a special file, the opening and subsequent IOs perform non-blocking operations.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_sync_007', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_open_sync_007');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.NONBLOCK | fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_open_sync_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_SYNC_0800
+ * @tc.name fileIO_test_open_sync_008
+ * @tc.desc Test openSync() interfaces. mode=0o200000.
+ * The path points to a directory.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_sync_008', 0, async function () {
+ let dpath = await nextFileName('fileIO_test_open_sync_008');
+ fileIO.mkdirSync(dpath);
+
+ try {
+ let file = fileIO.openSync(dpath, fileIO.OpenMode.DIR);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.rmdirSync(dpath);
+ } catch (e) {
+ console.log('fileIO_test_open_sync_008 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_SYNC_0900
+ * @tc.name fileIO_test_open_sync_009
+ * @tc.desc Test openSync() interfaces. mode=0o200000.
+ * The path does not a directory, throw error.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_sync_009', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_open_sync_009');
+ expect(prepareFile(fpath, '')).assertTrue();
+
+ try {
+ fileIO.openSync(fpath, fileIO.OpenMode.DIR);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_open_sync_009 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900018 && e.message == 'Not a directory').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_SYNC_1000
+ * @tc.name fileIO_test_open_sync_010
+ * @tc.desc Test openSync() interfaces. mode=0o400002.
+ * The path does not point to a symbolic link.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_sync_010', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_open_sync_010');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.NOFOLLOW | fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_open_sync_010 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_SYNC_1100
+ * @tc.name fileIO_test_open_sync_011
+ * @tc.desc Test openSync() interfaces. mode=0o400002.
+ * The path points to a symbolic link, throw error.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_sync_011', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_open_sync_011');
+ let ffpath = fpath + 'aaaa';
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.symlinkSync(fpath, ffpath);
+ fileIO.openSync(ffpath, fileIO.OpenMode.NOFOLLOW | fileIO.OpenMode.READ_WRITE);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ fileIO.unlinkSync(ffpath);
+ console.log('fileIO_test_open_sync_011 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900033 && e.message == 'Too many symbolic links encountered').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_SYNC_1200
+ * @tc.name fileIO_test_open_sync_012
+ * @tc.desc Test openSync() interfaces. mode=0o4010002.
+ * Open the file in the way of synchronous IO.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_sync_012', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_open_sync_012');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.SYNC | fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_open_sync_012 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_SYNC_1300
+ * @tc.name fileIO_test_open_sync_013
+ * @tc.desc Test openSync() interfaces. Invalid path.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_sync_013', 0, async function () {
+
+ try {
+ fileIO.openSync(-1, fileIO.OpenMode.READ_WRITE);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_open_sync_013 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_SYNC_1400
+ * @tc.name fileIO_test_open_sync_014
+ * @tc.desc Test openSync() interfaces. mode=0o200000.
+ * The path refers to a directory, not a file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_sync_014', 0, async function () {
+ let dpath = await nextFileName('fileIO_test_open_sync_012');
+ fileIO.mkdirSync(dpath);
+
+ try {
+ fileIO.openSync(dpath, fileIO.OpenMode.READ_WRITE);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.rmdirSync(dpath);
+ console.log('fileIO_test_open_sync_014 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900019 && e.message == 'Is a directory').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_SYNC_1500
+ * @tc.name fileIO_test_open_sync_015
+ * @tc.desc Test openSync() interfaces.
+ * Undefined option arguments, use default mode = 0o0.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_sync_015', 3, async function () {
+ let fpath = await nextFileName('fileIO_test_open_sync_015');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file;
+
+ try {
+ file = fileIO.openSync(fpath, undefined);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readlen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
+ expect(readlen == FILE_CONTENT.length).assertTrue();
+ fileIO.writeSync(file.fd, new ArrayBuffer(4096));
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_open_sync_015 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900008 && e.message == 'Bad file descriptor').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_0000
+ * @tc.name fileIO_test_open_async_000
+ * @tc.desc Test open() interfaces. mode=0o0. Promise.
+ * Open the file in read-only mode, verifying the file is readable.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_open_async_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_open_async_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = await fileIO.open(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.read(file.fd, new ArrayBuffer(4096))
+ .then((readLen) => {
+ expect(readLen == FILE_CONTENT.length).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_open_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_0100
+ * @tc.name fileIO_test_open_async_001
+ * @tc.desc Test open() interfaces. mode=0o0. Callback.
+ * Open the file in read-only mode, verifying the file is readable.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_open_async_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.open(fpath, fileIO.OpenMode.READ_ONLY, (err, file) => {
+ if(err) {
+ console.log('fileIO_test_open_async_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.read(file.fd, new ArrayBuffer(4096))
+ .then((readLen) => {
+ expect(readLen == FILE_CONTENT.length).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ });
+ } catch (e) {
+ console.log('fileIO_test_open_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_0200
+ * @tc.name fileIO_test_open_async_002
+ * @tc.desc Test open() interfaces. mode=0o1. Promise.
+ * Open the file in write-only mode, verifying the file is writable.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_002', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_open_async_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let length = 20;
+
+ try {
+ let file = await fileIO.open(fpath, fileIO.OpenMode.WRITE_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.write(file.fd, new ArrayBuffer(length))
+ .then((bytesWritten) => {
+ expect(bytesWritten == length).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_open_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_0300
+ * @tc.name fileIO_test_open_async_003
+ * @tc.desc Test open() interfaces. mode=0o1. Callback.
+ * Open the file in write-only mode, verifying the file is writable.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_003', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_open_async_003');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let length = 20;
+
+ try {
+ fileIO.open(fpath, fileIO.OpenMode.WRITE_ONLY, (err, file) => {
+ if(err) {
+ console.log('fileIO_test_open_async_003 error package' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.write(file.fd, new ArrayBuffer(length))
+ .then((bytesWritten) => {
+ expect(bytesWritten == length).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ });
+ });
+ done();
+ } catch (e) {
+ console.log('fileIO_test_open_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_0400
+ * @tc.name fileIO_test_open_async_004
+ * @tc.desc Test open() interfaces. mode=0o2. Promise.
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_004', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_open_async_004');
+
+ try {
+ await fileIO.open(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_open_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_0500
+ * @tc.name fileIO_test_open_async_005
+ * @tc.desc Test open() interfaces. mode=0o2. Callback.
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_005', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_open_async_005');
+
+ try {
+ fileIO.open(fpath, fileIO.OpenMode.READ_WRITE, (err) => {
+ if(err) {
+ console.log('fileIO_test_open_async_005 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('fileIO_test_open_async_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_0600
+ * @tc.name fileIO_test_open_async_006
+ * @tc.desc Test open() interfaces. mode=0o2. Promise.then().catch()
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_006', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_open_async_006');
+
+ try {
+ fileIO.open(fpath, fileIO.OpenMode.READ_WRITE).then(() => {
+ expect(false).assertTrue();
+ }).catch((err) => {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_open_async_006 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
+ });
+ } catch (e) {
+ console.log('fileIO_test_open_async_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_0700
+ * @tc.name fileIO_test_open_async_007
+ * @tc.desc Test open() interfaces. Promise.
+ * Invalid path.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_007', 0, async function (done) {
+
+ try {
+ await fileIO.open(-1, fileIO.OpenMode.READ_WRITE);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_open_async_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_0800
+ * @tc.name fileIO_test_open_async_008
+ * @tc.desc Test open() interfaces. Callback.
+ * Invalid path.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_008', 0, async function (done) {
+
+ try {
+ fileIO.open(-1, fileIO.OpenMode.READ_WRITE, (err) => {
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ console.log('fileIO_test_open_async_008 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_0900
+ * @tc.name fileIO_test_open_async_009
+ * @tc.desc Test open() interfaces. mode=0o102. Promise.
+ * If the path point to the file which does not exist, the file can be created.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_009', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_open_async_009');
+
+ try {
+ let file = await fileIO.open(fpath, fileIO.OpenMode.CREATE | fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_open_async_009 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_1000
+ * @tc.name fileIO_test_open_async_010
+ * @tc.desc Test open() interfaces. mode=0o102. Callback.
+ * If the path point to the file which does not exist, the file can be created.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_010', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_open_async_010');
+
+ try {
+ fileIO.open(fpath, fileIO.OpenMode.CREATE | fileIO.OpenMode.WRITE_ONLY, (err, file) => {
+ if(err) {
+ console.log('fileIO_test_open_async_010 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_open_async_010 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_1100
+ * @tc.name fileIO_test_open_async_011
+ * @tc.desc Test open() interfaces. mode=0o1002. Promise.
+ * If the file exists and the file is opened for read-write, trim its length to zero.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_011', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_open_async_011');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = await fileIO.open(fpath, fileIO.OpenMode.TRUNC | fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.read(file.fd, new ArrayBuffer(4096))
+ .then((readLen) => {
+ expect(readLen == 0).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ });
+ done();
+ } catch (e) {
+ console.log('fileIO_test_open_async_011 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_1200
+ * @tc.name fileIO_test_open_async_012
+ * @tc.desc Test open() interfaces. mode=0o1002. Callback.
+ * If the file exists and the file is opened for read-write, trim its length to zero.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_012', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_open_async_012');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.open(fpath, fileIO.OpenMode.TRUNC | fileIO.OpenMode.READ_WRITE, (err, file) => {
+ if(err) {
+ console.log('fileIO_test_open_async_012 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.read(file.fd, new ArrayBuffer(4096))
+ .then((readLen) => {
+ expect(readLen == 0).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ });
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_open_async_012 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_1300
+ * @tc.name fileIO_test_open_async_013
+ * @tc.desc Test open() interfaces. mode=0o2002. Promise.
+ * Open as append, subsequent writes will append to the end of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_013', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_open_async_013');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let length = 100;
+
+ try {
+ let file = await fileIO.open(fpath, fileIO.OpenMode.APPEND | fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.writeSync(file.fd, new ArrayBuffer(length));
+ fileIO.read(file.fd, new ArrayBuffer(4096), { offset: 0 })
+ .then((readLen) => {
+ expect(readLen == length + FILE_CONTENT.length).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ });
+ done();
+ } catch (e) {
+ console.log('fileIO_test_open_async_013 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_1400
+ * @tc.name fileIO_test_open_async_014
+ * @tc.desc Test open() interfaces. mode=0o2002. Callback.
+ * Open as append, subsequent writes will append to the end of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_014', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_open_async_014');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let length = 100;
+
+ try {
+ fileIO.open(fpath, fileIO.OpenMode.APPEND | fileIO.OpenMode.READ_WRITE, (err, file) => {
+ if(err) {
+ console.log('fileIO_test_open_async_014 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.writeSync(file.fd, new ArrayBuffer(length));
+ fileIO.read(file.fd, new ArrayBuffer(4096), { offset: 0 })
+ .then((readLen) => {
+ expect(readLen == length + FILE_CONTENT.length).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ });
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_open_async_014 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_1500
+ * @tc.name fileIO_test_open_async_015
+ * @tc.desc Test open() interfaces. mode=0o4002. Promise.
+ * If the file is a special file, the opening and subsequent IOs perform non-blocking operations.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_015', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_open_async_015');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = await fileIO.open(fpath, fileIO.OpenMode.NONBLOCK | fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_open_async_015 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_1600
+ * @tc.name fileIO_test_open_async_016
+ * @tc.desc Test open() interfaces. mode=0o4002. Callback.
+ * If the file is a special file, the opening and subsequent IOs perform non-blocking operations.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_016', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_open_async_016');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.open(fpath, fileIO.OpenMode.NONBLOCK | fileIO.OpenMode.READ_WRITE, (err, file) => {
+ if(err) {
+ console.log('fileIO_test_open_async_016 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_open_async_016 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_1700
+ * @tc.name fileIO_test_open_async_017
+ * @tc.desc Test open() interfaces. mode=0o200000. Promise.
+ * The path points to a directory.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_017', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_open_async_017');
+ fileIO.mkdirSync(dpath);
+
+ try {
+ let file = await fileIO.open(dpath, fileIO.OpenMode.DIR);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.rmdirSync(dpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_open_async_017 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_1800
+ * @tc.name fileIO_test_open_async_018
+ * @tc.desc Test open() interfaces. mode=0o200000. Callback.
+ * The path points to a directory.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_018', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_open_async_018');
+ fileIO.mkdirSync(dpath);
+
+ try {
+ fileIO.open(dpath, fileIO.OpenMode.DIR, (err, file) => {
+ if(err) {
+ console.log('fileIO_test_open_async_018 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.rmdirSync(dpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_open_async_018 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_1900
+ * @tc.name fileIO_test_open_async_019
+ * @tc.desc Test open() interfaces. mode=0o200000. Promise.
+ * The path does not point to a directory, throw error.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_019', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_open_async_019');
+ expect(prepareFile(fpath, '')).assertTrue();
+
+ try {
+ await fileIO.open(fpath, fileIO.OpenMode.DIR);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_open_async_019 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900018 && e.message == 'Not a directory').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_2000
+ * @tc.name fileIO_test_open_async_020
+ * @tc.desc Test open() interfaces. mode=0o200000. Callback.
+ * The path does not point to a directory, throw error.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_020', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_open_async_020');
+ expect(prepareFile(fpath, '')).assertTrue();
+
+ try {
+ fileIO.open(fpath, fileIO.OpenMode.DIR, (err) => {
+ if(err) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_open_async_020 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900018 && err.message == 'Not a directory').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('fileIO_test_open_async_020 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_2100
+ * @tc.name fileIO_test_open_async_021
+ * @tc.desc Test open() interfaces. mode=0o200000. Promise.then().catch().
+ * The path does not point to a directory, throw error.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_021', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_open_async_021');
+ expect(prepareFile(fpath, '')).assertTrue();
+
+ try {
+ fileIO.open(fpath, fileIO.OpenMode.DIR).then(() => {
+ expect(false).assertTrue();
+ }).catch((err) => {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_open_async_021 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900018 && err.message == 'Not a directory').assertTrue();
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_open_async_021 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_2200
+ * @tc.name fileIO_test_open_async_022
+ * @tc.desc Test open() interfaces. mode=0o400002. Promise.
+ * The path does not point to a symbolic link.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_022', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_open_async_022');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = await fileIO.open(fpath, fileIO.OpenMode.NOFOLLOW | fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_open_async_022 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_2300
+ * @tc.name fileIO_test_open_async_023
+ * @tc.desc Test open() interfaces. mode=0o400002. Callback.
+ * The path does not point to a symbolic link.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_023', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_open_async_023');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.open(fpath, fileIO.OpenMode.NOFOLLOW | fileIO.OpenMode.READ_WRITE, (err, file) => {
+ if(err) {
+ console.log('fileIO_test_open_async_023 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_open_async_023 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_2400
+ * @tc.name fileIO_test_open_async_024
+ * @tc.desc Test open() interfaces. mode=0o400002. Promise.
+ * The path point to a symbolic link, throw error.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_024', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_open_async_024');
+ let ffpath = fpath + 'aaaa';
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.symlinkSync(fpath, ffpath);
+ await fileIO.open(ffpath, fileIO.OpenMode.NOFOLLOW | fileIO.OpenMode.READ_WRITE);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ fileIO.unlinkSync(ffpath);
+ console.log('fileIO_test_open_async_024 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900033 && e.message == 'Too many symbolic links encountered').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_2500
+ * @tc.name fileIO_test_open_async_025
+ * @tc.desc Test open() interfaces. mode=0o400002. Callback.
+ * The path point to a symbolic link, throw error.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_025', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_open_async_025');
+ let ffpath = fpath + 'link';
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.symlinkSync(fpath, ffpath);
+ fileIO.open(ffpath, fileIO.OpenMode.NOFOLLOW | fileIO.OpenMode.READ_WRITE, (err) => {
+ if(err) {
+ console.log('fileIO_test_open_async_025 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900033 && err.message == 'Too many symbolic links encountered').assertTrue();
+ }
+ fileIO.unlinkSync(fpath);
+ fileIO.unlinkSync(ffpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_open_async_025 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_2600
+ * @tc.name fileIO_test_open_async_026
+ * @tc.desc Test open() interfaces. mode=0o400002. Promise.then().catch()
+ * The path point to a symbolic link, throw error.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_026', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_open_async_026');
+ let ffpath = fpath + 'link';
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.symlinkSync(fpath, ffpath);
+ fileIO.open(ffpath, fileIO.OpenMode.NOFOLLOW | fileIO.OpenMode.READ_WRITE).then(() => {
+ expect(false).assertTrue();
+ }).catch((err) => {
+ console.log('fileIO_test_open_async_026 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900033 && err.message == 'Too many symbolic links encountered').assertTrue();
+ fileIO.unlinkSync(fpath);
+ fileIO.unlinkSync(ffpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_open_async_026 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_2700
+ * @tc.name fileIO_test_open_async_027
+ * @tc.desc Test open() interfaces. mode=0o4010002. Promise.
+ * Open the file in the way of synchronous IO.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_027', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_open_async_027');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = await fileIO.open(fpath, fileIO.OpenMode.SYNC | fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_open_async_027 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_2800
+ * @tc.name fileIO_test_open_async_028
+ * @tc.desc Test open() interfaces. mode=0o4010002. Callback.
+ * Open the file in the way of synchronous IO.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_028', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_open_async_028');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.open(fpath, fileIO.OpenMode.SYNC | fileIO.OpenMode.READ_WRITE, (err, file) => {
+ if(err) {
+ console.log('fileIO_test_open_async_028 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_open_async_028 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_2900
+ * @tc.name fileIO_test_open_async_029
+ * @tc.desc Test open() interfaces. Promise.
+ * The path refers to a file, not a directory.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_029', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_open_async_029');
+ fileIO.mkdirSync(dpath);
+
+ try {
+ await fileIO.open(dpath, fileIO.OpenMode.READ_WRITE);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.rmdirSync(dpath);
+ console.log('fileIO_test_open_async_029 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900019 && e.message == 'Is a directory').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_3000
+ * @tc.name fileIO_test_open_async_030
+ * @tc.desc Test open() interfaces. Callback.
+ * The path refers to a file, not a directory.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_030', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_open_async_030');
+ fileIO.mkdirSync(dpath);
+
+ try {
+ fileIO.open(dpath, fileIO.OpenMode.READ_WRITE, (err, file) => {
+ if (err) {
+ fileIO.rmdirSync(dpath);
+ console.log('fileIO_test_open_async_030 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900019 && err.message == 'Is a directory').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('fileIO_test_open_async_030 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_3100
+ * @tc.name fileIO_test_open_async_031
+ * @tc.desc Test open() interfaces. Promise.
+ * Undefined option arguments, use default mode = 0o0.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_031', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_open_async_031');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file;
+
+ try {
+ file = await fileIO.open(fpath, undefined);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
+ expect(readLen == FILE_CONTENT.length).assertTrue();
+ fileIO.writeSync(file.fd, new ArrayBuffer(4096));
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_open_async_031 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900008 && e.message == 'Bad file descriptor').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_OPEN_ASYNC_3200
+ * @tc.name fileIO_test_open_async_032
+ * @tc.desc Test open() interfaces. Callback.
+ * Undefined option arguments, use default mode = 0o0.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_open_async_032', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_test_open_async_032');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.open(fpath, undefined, (err, file) => {
+ if (err) {
+ console.log('fileIO_test_open_async_032 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(file.fd)).assertTrue();
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
+ expect(readLen == FILE_CONTENT.length).assertTrue();
+ fileIO.write(file.fd, new ArrayBuffer(4096), (err, bytesWritten) => {
+ if (err) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_open_async_032 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900008 && err.message == 'Bad file descriptor').assertTrue();
+ done();
+ } else {
+ expect(false).assertTrue();
+ }
+ });
+ });
+ } catch (e) {
+ console.log('fileIO_test_open_async_032 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+});
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/read.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/read.test.js
similarity index 97%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/read.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/read.test.js
index e7bab16274abcf7f42314a39d6d477190ad3e156..7ca5cdc98ed762bd9891369f6fb30c0db7f11878 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/read.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/members/read.test.js
@@ -1,1182 +1,1182 @@
-/*
- * Copyright (C) 2022 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the 'License');
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an 'AS IS' BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import {
- fileIO, FILE_CONTENT, prepareFile, nextFileName, isIntNum, describe, it, expect, util
-} from '../Common';
-
-export default function fileIORead() {
- describe('fileIO_fs_read', function () {
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_SYNC_0000
- * @tc.name fileIO_test_read_sync_000
- * @tc.desc Test readSync() interfaces.
- * Open the file in read-only mode, default read from current offset.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_read_sync_000', 0, async function () {
- let fpath = await nextFileName('fileIO_test_read_sync_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let readLen1 = fileIO.readSync(file.fd, new ArrayBuffer(16));
- expect(readLen1 == FILE_CONTENT.length).assertTrue();
- let readLen2 = fileIO.readSync(file.fd, new ArrayBuffer(8));
- expect(readLen2 == 0).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_read_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_SYNC_0100
- * @tc.name fileIO_test_read_sync_001
- * @tc.desc Test readSync() interfaces.
- * Open the file in read-only mode, reading the file with length = 1.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_sync_001', 0, async function () {
- let fpath = await nextFileName('fileIO_test_read_sync_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), {
- length: 1,
- });
- expect(readLen == 1).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_read_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_SYNC_0200
- * @tc.name fileIO_test_read_sync_002
- * @tc.desc Test readSync() interfaces.
- * Open the file in read-only mode, reading the file with length = -1((0 < length < buffer.size)).
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_sync_002', 0, async function () {
- let fpath = await nextFileName('fileIO_test_read_sync_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- const invalidLength = -1;
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.readSync(file.fd, new ArrayBuffer(4096), {
- length: invalidLength,
- });
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_read_sync_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_SYNC_0300
- * @tc.name fileIO_test_read_sync_003
- * @tc.desc Test readSync() interfaces.
- * Open the file in read-only mode, reading the file with length > the content of file(Read normal).
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_sync_003', 0, async function () {
- let fpath = await nextFileName('fileIO_test_read_sync_003');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), {
- length: FILE_CONTENT.length + 1,
- });
- expect(readLen == FILE_CONTENT.length).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_read_sync_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_SYNC_0400
- * @tc.name fileIO_test_read_sync_004
- * @tc.desc Test readSync() interfaces.
- * Read the file with invalid length > size of ArrayBuffer.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_sync_004', 0, async function () {
- let fpath = await nextFileName('fileIO_test_read_sync_004');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.readSync(file.fd, new ArrayBuffer(4096), {
- length: 4097,
- });
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_read_sync_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_SYNC_0500
- * @tc.name fileIO_test_read_sync_005
- * @tc.desc Test readSync() interfaces.
- * Open the file in read-only mode, reading the file with offset(position) = 1.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_sync_005', 0, async function () {
- let fpath = await nextFileName('fileIO_test_read_sync_005');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), {
- offset: 1,
- });
- expect(readLen == FILE_CONTENT.length - 1).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_read_sync_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_SYNC_0600
- * @tc.name fileIO_test_read_sync_006
- * @tc.desc Test readSync() interfaces.
- * Read the file with invalid offset = -1.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_sync_006', 0, async function () {
- let fpath = await nextFileName('fileIO_test_read_sync_006');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- const invalidOffset = -1;
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.readSync(file.fd, new ArrayBuffer(4096), {
- offset: invalidOffset,
- });
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_read_sync_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_SYNC_0700
- * @tc.name fileIO_test_read_sync_007
- * @tc.desc Test readSync() interfaces.
- * Open the file in read-only mode, reading the file with offset(position) > the content of file(Read normal).
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_sync_007', 0, async function () {
- let fpath = await nextFileName('fileIO_test_read_sync_007');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), {
- offset: FILE_CONTENT.length + 1,
- });
- expect(readLen == 0).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_read_sync_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_SYNC_0800
- * @tc.name fileIO_test_read_sync_008
- * @tc.desc Test readSync() interfaces.
- * Open the file in read-only mode, reading the file with offset(position) = 1, length = 10.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_sync_008', 0, async function () {
- let fpath = await nextFileName('fileIO_test_read_sync_008');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), {
- offset: 1,
- length: FILE_CONTENT.length - 1,
- });
- expect(readLen == FILE_CONTENT.length - 1).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_read_sync_008 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_SYNC_0900
- * @tc.name fileIO_test_read_sync_009
- * @tc.desc Test readSync() interfaces.
- * Read the file with invalid fd.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_sync_009', 0, async function () {
-
- try {
- fileIO.readSync(-1, new ArrayBuffer(4096));
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_read_sync_009 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_SYNC_1000
- * @tc.name fileIO_test_read_sync_010
- * @tc.desc Test readSync() interfaces.
- * Verify that the Chinese, English, and symbols can be read correctly.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_sync_010', 0, async function () {
- let fpath = await nextFileName('fileIO_test_read_sync_010');
- let CONTENT = ""
- expect(prepareFile(fpath, CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let buf = new ArrayBuffer(4096);
- fileIO.readSync(file.fd, buf);
- let textDecoder = new util.TextDecoder("utf-8", { ignoreBOM: true });
- let resultPut = textDecoder.decode(new Uint8Array(buf), { stream: true });
- expect(resultPut == CONTENT).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_read_sync_010 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_SYNC_1100
- * @tc.name fileIO_test_read_sync_011
- * @tc.desc Test readSync() interfaces.
- * Undefined option arguments, use default options.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_sync_011', 3, async function () {
- let fpath = await nextFileName('fileIO_test_read_sync_011');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let readLen1 = fileIO.readSync(file.fd, new ArrayBuffer(16), undefined);
- expect(readLen1 == FILE_CONTENT.length).assertTrue();
- let readLen2 = fileIO.readSync(file.fd, new ArrayBuffer(8), undefined);
- expect(readLen2 == 0).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_read_sync_011 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_SYNC_1200
- * @tc.name fileIO_test_read_sync_012
- * @tc.desc Test readSync() interfaces.
- * Undefined option arguments, use default options.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_sync_012', 3, async function () {
- let fpath = await nextFileName('fileIO_test_read_sync_012');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let readLen1 = fileIO.readSync(file.fd, new ArrayBuffer(16), {
- offset: undefined,
- length: undefined,
- });
- expect(readLen1 == FILE_CONTENT.length).assertTrue();
- let readLen2 = fileIO.readSync(file.fd, new ArrayBuffer(8), {
- offset: undefined,
- length: undefined,
- });
- expect(readLen2 == 0).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_read_sync_012 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_ASYNC_0000
- * @tc.name fileIO_test_read_async_000
- * @tc.desc Test read() interfaces. Promise.
- * Open the file in read-only mode, default read from current offset.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_read_async_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_read_async_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let readLen1 = await fileIO.read(file.fd, new ArrayBuffer(16));
- expect(readLen1 == FILE_CONTENT.length).assertTrue();
- let readLen2 = await fileIO.read(file.fd, new ArrayBuffer(8));
- expect(readLen2 == 0).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_read_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_ASYNC_0100
- * @tc.name fileIO_test_read_async_001
- * @tc.desc Test read() interfaces. Callback.
- * Open the file in read-only mode, default read from current offset.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_async_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_read_async_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.read(file.fd, new ArrayBuffer(16), (err, readlen1) => {
- if (err) {
- console.log('fileIO_test_read_async_001 err package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(readlen1 == FILE_CONTENT.length).assertTrue();
- fileIO.read(file.fd, new ArrayBuffer(8), (err, readLen2) => {
- if (err) {
- console.log('fileIO_test_read_async_001 err package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(readLen2 == 0).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- });
- } catch (e) {
- console.log('fileIO_test_read_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_ASYNC_0200
- * @tc.name fileIO_test_read_async_002
- * @tc.desc Test read() interfaces. Promise.
- * Open the file in write-only mode, verifying it is not readable.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_async_002', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_read_async_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- await fileIO.read(file.fd, new ArrayBuffer(4096));
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_read_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900008 && e.message == 'Bad file descriptor').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_ASYNC_0300
- * @tc.name fileIO_test_read_async_003
- * @tc.desc Test read() interfaces. Callback.
- * Open the file in write-only mode, verifying it is not readable.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_async_003', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_read_async_003');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file;
-
- try {
- file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.read(file.fd, new ArrayBuffer(4096), (err) => {
- if(err) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_read_async_003 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900008 && err.message == 'Bad file descriptor').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('fileIO_test_read_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_ASYNC_0400
- * @tc.name fileIO_test_read_async_004
- * @tc.desc Test read() interfaces. Promise.
- * Open the file in read-only mode, reading the file with offset(position) = 1.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_async_004', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_read_async_004');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let readlen = await fileIO.read(file.fd, new ArrayBuffer(4096), {
- offset: 1,
- });
- expect(readlen == FILE_CONTENT.length - 1).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_read_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_ASYNC_0500
- * @tc.name fileIO_test_read_async_005
- * @tc.desc Test read() interfaces. Callback.
- * Open the file in read-only mode, reading the file with offset(position) = 1.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_async_005', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_read_async_005');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.read(file.fd, new ArrayBuffer(4096), {
- offset: 1,
- }, (err, readLen) => {
- if(err) {
- console.log('fileIO_test_read_async_005 err package' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(readLen == FILE_CONTENT.length - 1).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_read_async_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_ASYNC_0600
- * @tc.name fileIO_test_read_async_006
- * @tc.desc Test read() interface. Promise.
- * Open the file in read-only mode, reading the file with length = 1.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_async_006', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_read_async_006');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let readLen = await fileIO.read(file.fd, new ArrayBuffer(4096), {
- length: 3,
- });
- expect(readLen == 3).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_read_async_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_ASYNC_0700
- * @tc.name fileIO_test_read_async_007
- * @tc.desc Test read() interface. Callback.
- * Open the file in read-only mode, reading the file with length = 1.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_async_007', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_read_async_007');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.read(file.fd, new ArrayBuffer(4096), {
- length: 3,
- }, (err, readLen) => {
- if(err) {
- console.log('fileIO_test_read_async_007 err package' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(readLen == 3).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_read_async_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_ASYNC_0800
- * @tc.name fileIO_test_read_async_008
- * @tc.desc Test read() interfaces. Promise.
- * Open the file in read-only mode, reading the file with offset > the content of file(Read normal).
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_async_008', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_read_async_008');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let readLen = await fileIO.read(file.fd, new ArrayBuffer(4096), {
- offset: FILE_CONTENT.length + 1,
- });
- expect(readLen == 0).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_read_async_008 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_ASYNC_0900
- * @tc.name fileIO_test_read_async_009
- * @tc.desc Test read() interfaces. Callback.
- * Open the file in read-only mode, reading the file with offset > the content of file(Read normal).
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_async_009', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_read_async_009');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.read(file.fd, new ArrayBuffer(4096), {
- offset: FILE_CONTENT.length + 1,
- }, (err, readLen) => {
- if(err) {
- console.log('fileIO_test_read_async_009 err package' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(readLen == 0).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_read_async_009 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_ASYNC_1000
- * @tc.name fileIO_test_read_async_010
- * @tc.desc Test read() interfaces.
- * Open the file in read-only mode, reading the file with offset(position) = 1, length = 11.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_async_010', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_read_async_010');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let readLen = await fileIO.read(file.fd, new ArrayBuffer(4096), {
- offset: 1,
- length: FILE_CONTENT.length,
- });
- expect(readLen == FILE_CONTENT.length - 1).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_read_async_010 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_ASYNC_1100
- * @tc.name fileIO_test_read_async_011
- * @tc.desc Test read() interfaces. Callback.
- * Open the file in read-only mode, reading the file with offset(position) = 1, length = 11.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_async_011', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_read_async_011');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.read(file.fd, new ArrayBuffer(4096), {
- offset: 1,
- length: FILE_CONTENT.length,
- }, (err, readLen) => {
- if(err) {
- console.log('fileIO_test_read_async_011 err package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(readLen == FILE_CONTENT.length - 1).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_read_async_011 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_ASYNC_1200
- * @tc.name fileIO_test_read_async_012
- * @tc.desc Test read() interfaces. Promise.
- * Read with invalid fd parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_async_012', 0, async function (done) {
- try {
- await fileIO.read(-1, new ArrayBuffer(4096));
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_read_async_012 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_ASYNC_1300
- * @tc.name fileIO_test_read_async_013
- * @tc.desc Test read() interfaces. Callback.
- * Read with invalid fd parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_async_013', 0, async function (done) {
- try {
- fileIO.read(-1, new ArrayBuffer(4096), (err) => {
- if(err) {
- expect(false).assertTrue();
- }
- });
- } catch (e) {
- console.log('fileIO_test_read_async_013 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_ASYNC_1400
- * @tc.name fileIO_test_read_async_014
- * @tc.desc Test read() interfaces. Callback.
- * Read with invalid offset < 0.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_async_014', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_read_async_014');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- const invalidOffset = -1;
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.read(file.fd, new ArrayBuffer(4096), {
- offset: invalidOffset,
- }, (err) => {
- expect(false).assertTrue();
- });
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_read_async_014 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_ASYNC_1500
- * @tc.name fileIO_test_read_async_015
- * @tc.desc Test read() interfaces. Callback.
- * Read with invalid length > size of ArrayBuffer(4096).
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_async_015', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_read_async_015');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- const invalidLength = 4097;
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.read(file.fd, new ArrayBuffer(4096), {
- length: invalidLength,
- }, (err) => {
- expect(false).assertTrue();
- });
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_read_async_015 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_ASYNC_1600
- * @tc.name fileIO_test_read_async_016
- * @tc.desc Test read() interfaces. Promise.
- * Open the file in read-only mode, reading the file with empty option.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_async_016', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_read_async_016');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let readLen = await fileIO.read(file.fd, new ArrayBuffer(4096), {});
- expect(readLen == FILE_CONTENT.length).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_read_async_016 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_ASYNC_1700
- * @tc.name fileIO_test_read_async_017
- * @tc.desc Test read() interfaces. Callback.
- * Open the file in read-only mode, reading the file with empty option.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_async_017', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_read_async_017');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.read(file.fd, new ArrayBuffer(4096), {
- }, (err, readLen) => {
- if(err) {
- console.log('fileIO_test_read_async_017 err package ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(readLen == FILE_CONTENT.length).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_read_async_017 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_ASYNC_1800
- * @tc.name fileIO_test_read_async_018
- * @tc.desc Test read() interfaces.
- * Open the file in read-only mode, reading the file with length = -1(0 < length < buffer.size).
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_async_018', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_read_async_018');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- const invalidLength = -1;
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- await fileIO.read(file.fd, new ArrayBuffer(4096), {
- length: invalidLength,
- });
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_read_async_018 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_ASYNC_1900
- * @tc.name fileIO_test_read_async_019
- * @tc.desc Test read() interfaces.
- * Verify that the Chinese, English, and symbols can be read correctly.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_async_019', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_read_async_019');
- let CONTENT = ""
- expect(prepareFile(fpath, CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let buf = new ArrayBuffer(4096);
- await fileIO.read(file.fd, buf);
- let textDecoder = new util.TextDecoder("utf-8", { ignoreBOM: true });
- let resultPut = textDecoder.decodeWithStream(new Uint8Array(buf), { stream: true });
- expect(resultPut == CONTENT).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_read_async_019 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_ASYNC_2000
- * @tc.name fileIO_test_read_async_020
- * @tc.desc Test read() interfaces. Promise.
- * Undefined option arguments, use default options.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_async_020', 3, async function (done) {
- let fpath = await nextFileName('fileIO_test_read_async_020');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let readLen1 = await fileIO.read(file.fd, new ArrayBuffer(16), undefined);
- expect(readLen1 == FILE_CONTENT.length).assertTrue();
- let readLen2 = await fileIO.read(file.fd, new ArrayBuffer(8), undefined);
- expect(readLen2 == 0).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_read_async_020 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_ASYNC_2100
- * @tc.name fileIO_test_read_async_021
- * @tc.desc Test read() interfaces. Callback.
- * Undefined option arguments, use default options.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_async_021', 3, async function (done) {
- let fpath = await nextFileName('fileIO_test_read_async_021');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.read(file.fd, new ArrayBuffer(16), undefined, (err, readlen1) => {
- if(err) {
- console.log('fileIO_test_read_async_021 err package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(readlen1 == FILE_CONTENT.length).assertTrue();
- fileIO.read(file.fd, new ArrayBuffer(8), undefined, (err, readLen2) => {
- if (err) {
- console.log('fileIO_test_read_async_021 err package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(readLen2 == 0).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- });
- } catch (e) {
- console.log('fileIO_test_read_async_021 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_ASYNC_2200
- * @tc.name fileIO_test_read_async_022
- * @tc.desc Test read() interfaces. Promise.
- * Undefined option arguments, use default options.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_async_022', 3, async function (done) {
- let fpath = await nextFileName('fileIO_test_read_async_022');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let readLen1 = await fileIO.read(file.fd, new ArrayBuffer(4096), {
- offset: undefined,
- length: undefined,
- });
- expect(readLen1 == FILE_CONTENT.length).assertTrue();
- let readLen2 = await fileIO.read(file.fd, new ArrayBuffer(8), {
- offset: undefined,
- length: undefined,
- });
- expect(readLen2 == 0).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_read_async_022 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_ASYNC_2300
- * @tc.name fileIO_test_read_async_023
- * @tc.desc Test read() interfaces. Callback.
- * Undefined option arguments, use default options.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_read_async_023', 3, async function (done) {
- let fpath = await nextFileName('fileIO_test_read_async_023');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.read(file.fd, new ArrayBuffer(16), {
- offset: undefined,
- length: undefined,
- }, (err, readLen1) => {
- if(err) {
- console.log('fileIO_test_read_async_011 err package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(readLen1 == FILE_CONTENT.length).assertTrue();
- fileIO.read(file.fd, new ArrayBuffer(8), {
- offset: undefined,
- length: undefined,
- }, (err, readLen2) => {
- if (err) {
- console.log('fileIO_test_read_async_001 err package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(readLen2 == 0).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- });
- } catch (e) {
- console.log('fileIO_test_read_async_023 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-});
-}
+/*
+ * Copyright (C) 2022 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import {
+ fileIO, FILE_CONTENT, prepareFile, nextFileName, isIntNum, describe, it, expect, util
+} from '../Common';
+
+export default function fileIORead() {
+ describe('fileIO_fs_read', function () {
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_SYNC_0000
+ * @tc.name fileIO_test_read_sync_000
+ * @tc.desc Test readSync() interfaces.
+ * Open the file in read-only mode, default read from current offset.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_read_sync_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_read_sync_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readLen1 = fileIO.readSync(file.fd, new ArrayBuffer(16));
+ expect(readLen1 == FILE_CONTENT.length).assertTrue();
+ let readLen2 = fileIO.readSync(file.fd, new ArrayBuffer(8));
+ expect(readLen2 == 0).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_read_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_SYNC_0100
+ * @tc.name fileIO_test_read_sync_001
+ * @tc.desc Test readSync() interfaces.
+ * Open the file in read-only mode, reading the file with length = 1.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_sync_001', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_read_sync_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), {
+ length: 1,
+ });
+ expect(readLen == 1).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_read_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_SYNC_0200
+ * @tc.name fileIO_test_read_sync_002
+ * @tc.desc Test readSync() interfaces.
+ * Open the file in read-only mode, reading the file with length = -1((0 < length < buffer.size)).
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_sync_002', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_read_sync_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ const invalidLength = -1;
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.readSync(file.fd, new ArrayBuffer(4096), {
+ length: invalidLength,
+ });
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_read_sync_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_SYNC_0300
+ * @tc.name fileIO_test_read_sync_003
+ * @tc.desc Test readSync() interfaces.
+ * Open the file in read-only mode, reading the file with length > the content of file(Read normal).
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_sync_003', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_read_sync_003');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), {
+ length: FILE_CONTENT.length + 1,
+ });
+ expect(readLen == FILE_CONTENT.length).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_read_sync_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_SYNC_0400
+ * @tc.name fileIO_test_read_sync_004
+ * @tc.desc Test readSync() interfaces.
+ * Read the file with invalid length > size of ArrayBuffer.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_sync_004', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_read_sync_004');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.readSync(file.fd, new ArrayBuffer(4096), {
+ length: 4097,
+ });
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_read_sync_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_SYNC_0500
+ * @tc.name fileIO_test_read_sync_005
+ * @tc.desc Test readSync() interfaces.
+ * Open the file in read-only mode, reading the file with offset(position) = 1.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_sync_005', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_read_sync_005');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), {
+ offset: 1,
+ });
+ expect(readLen == FILE_CONTENT.length - 1).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_read_sync_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_SYNC_0600
+ * @tc.name fileIO_test_read_sync_006
+ * @tc.desc Test readSync() interfaces.
+ * Read the file with invalid offset = -1.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_sync_006', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_read_sync_006');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ const invalidOffset = -1;
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.readSync(file.fd, new ArrayBuffer(4096), {
+ offset: invalidOffset,
+ });
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_read_sync_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_SYNC_0700
+ * @tc.name fileIO_test_read_sync_007
+ * @tc.desc Test readSync() interfaces.
+ * Open the file in read-only mode, reading the file with offset(position) > the content of file(Read normal).
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_sync_007', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_read_sync_007');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), {
+ offset: FILE_CONTENT.length + 1,
+ });
+ expect(readLen == 0).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_read_sync_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_SYNC_0800
+ * @tc.name fileIO_test_read_sync_008
+ * @tc.desc Test readSync() interfaces.
+ * Open the file in read-only mode, reading the file with offset(position) = 1, length = 10.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_sync_008', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_read_sync_008');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), {
+ offset: 1,
+ length: FILE_CONTENT.length - 1,
+ });
+ expect(readLen == FILE_CONTENT.length - 1).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_read_sync_008 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_SYNC_0900
+ * @tc.name fileIO_test_read_sync_009
+ * @tc.desc Test readSync() interfaces.
+ * Read the file with invalid fd.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_sync_009', 0, async function () {
+
+ try {
+ fileIO.readSync(-1, new ArrayBuffer(4096));
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_read_sync_009 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_SYNC_1000
+ * @tc.name fileIO_test_read_sync_010
+ * @tc.desc Test readSync() interfaces.
+ * Verify that the Chinese, English, and symbols can be read correctly.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_sync_010', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_read_sync_010');
+ let CONTENT = ""
+ expect(prepareFile(fpath, CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let buf = new ArrayBuffer(4096);
+ fileIO.readSync(file.fd, buf);
+ let textDecoder = new util.TextDecoder("utf-8", { ignoreBOM: true });
+ let resultPut = textDecoder.decode(new Uint8Array(buf), { stream: true });
+ expect(resultPut == CONTENT).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_read_sync_010 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_SYNC_1100
+ * @tc.name fileIO_test_read_sync_011
+ * @tc.desc Test readSync() interfaces.
+ * Undefined option arguments, use default options.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_sync_011', 3, async function () {
+ let fpath = await nextFileName('fileIO_test_read_sync_011');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readLen1 = fileIO.readSync(file.fd, new ArrayBuffer(16), undefined);
+ expect(readLen1 == FILE_CONTENT.length).assertTrue();
+ let readLen2 = fileIO.readSync(file.fd, new ArrayBuffer(8), undefined);
+ expect(readLen2 == 0).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_read_sync_011 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_SYNC_1200
+ * @tc.name fileIO_test_read_sync_012
+ * @tc.desc Test readSync() interfaces.
+ * Undefined option arguments, use default options.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_sync_012', 3, async function () {
+ let fpath = await nextFileName('fileIO_test_read_sync_012');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readLen1 = fileIO.readSync(file.fd, new ArrayBuffer(16), {
+ offset: undefined,
+ length: undefined,
+ });
+ expect(readLen1 == FILE_CONTENT.length).assertTrue();
+ let readLen2 = fileIO.readSync(file.fd, new ArrayBuffer(8), {
+ offset: undefined,
+ length: undefined,
+ });
+ expect(readLen2 == 0).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_read_sync_012 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_ASYNC_0000
+ * @tc.name fileIO_test_read_async_000
+ * @tc.desc Test read() interfaces. Promise.
+ * Open the file in read-only mode, default read from current offset.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_read_async_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_read_async_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readLen1 = await fileIO.read(file.fd, new ArrayBuffer(16));
+ expect(readLen1 == FILE_CONTENT.length).assertTrue();
+ let readLen2 = await fileIO.read(file.fd, new ArrayBuffer(8));
+ expect(readLen2 == 0).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_read_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_ASYNC_0100
+ * @tc.name fileIO_test_read_async_001
+ * @tc.desc Test read() interfaces. Callback.
+ * Open the file in read-only mode, default read from current offset.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_async_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_read_async_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.read(file.fd, new ArrayBuffer(16), (err, readlen1) => {
+ if (err) {
+ console.log('fileIO_test_read_async_001 err package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(readlen1 == FILE_CONTENT.length).assertTrue();
+ fileIO.read(file.fd, new ArrayBuffer(8), (err, readLen2) => {
+ if (err) {
+ console.log('fileIO_test_read_async_001 err package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(readLen2 == 0).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ });
+ } catch (e) {
+ console.log('fileIO_test_read_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_ASYNC_0200
+ * @tc.name fileIO_test_read_async_002
+ * @tc.desc Test read() interfaces. Promise.
+ * Open the file in write-only mode, verifying it is not readable.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_async_002', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_read_async_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ await fileIO.read(file.fd, new ArrayBuffer(4096));
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_read_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900008 && e.message == 'Bad file descriptor').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_ASYNC_0300
+ * @tc.name fileIO_test_read_async_003
+ * @tc.desc Test read() interfaces. Callback.
+ * Open the file in write-only mode, verifying it is not readable.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_async_003', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_read_async_003');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file;
+
+ try {
+ file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.read(file.fd, new ArrayBuffer(4096), (err) => {
+ if(err) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_read_async_003 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900008 && err.message == 'Bad file descriptor').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('fileIO_test_read_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_ASYNC_0400
+ * @tc.name fileIO_test_read_async_004
+ * @tc.desc Test read() interfaces. Promise.
+ * Open the file in read-only mode, reading the file with offset(position) = 1.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_async_004', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_read_async_004');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readlen = await fileIO.read(file.fd, new ArrayBuffer(4096), {
+ offset: 1,
+ });
+ expect(readlen == FILE_CONTENT.length - 1).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_read_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_ASYNC_0500
+ * @tc.name fileIO_test_read_async_005
+ * @tc.desc Test read() interfaces. Callback.
+ * Open the file in read-only mode, reading the file with offset(position) = 1.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_async_005', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_read_async_005');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.read(file.fd, new ArrayBuffer(4096), {
+ offset: 1,
+ }, (err, readLen) => {
+ if(err) {
+ console.log('fileIO_test_read_async_005 err package' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(readLen == FILE_CONTENT.length - 1).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_read_async_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_ASYNC_0600
+ * @tc.name fileIO_test_read_async_006
+ * @tc.desc Test read() interface. Promise.
+ * Open the file in read-only mode, reading the file with length = 1.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_async_006', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_read_async_006');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readLen = await fileIO.read(file.fd, new ArrayBuffer(4096), {
+ length: 3,
+ });
+ expect(readLen == 3).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_read_async_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_ASYNC_0700
+ * @tc.name fileIO_test_read_async_007
+ * @tc.desc Test read() interface. Callback.
+ * Open the file in read-only mode, reading the file with length = 1.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_async_007', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_read_async_007');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.read(file.fd, new ArrayBuffer(4096), {
+ length: 3,
+ }, (err, readLen) => {
+ if(err) {
+ console.log('fileIO_test_read_async_007 err package' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(readLen == 3).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_read_async_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_ASYNC_0800
+ * @tc.name fileIO_test_read_async_008
+ * @tc.desc Test read() interfaces. Promise.
+ * Open the file in read-only mode, reading the file with offset > the content of file(Read normal).
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_async_008', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_read_async_008');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readLen = await fileIO.read(file.fd, new ArrayBuffer(4096), {
+ offset: FILE_CONTENT.length + 1,
+ });
+ expect(readLen == 0).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_read_async_008 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_ASYNC_0900
+ * @tc.name fileIO_test_read_async_009
+ * @tc.desc Test read() interfaces. Callback.
+ * Open the file in read-only mode, reading the file with offset > the content of file(Read normal).
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_async_009', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_read_async_009');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.read(file.fd, new ArrayBuffer(4096), {
+ offset: FILE_CONTENT.length + 1,
+ }, (err, readLen) => {
+ if(err) {
+ console.log('fileIO_test_read_async_009 err package' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(readLen == 0).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_read_async_009 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_ASYNC_1000
+ * @tc.name fileIO_test_read_async_010
+ * @tc.desc Test read() interfaces.
+ * Open the file in read-only mode, reading the file with offset(position) = 1, length = 11.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_async_010', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_read_async_010');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readLen = await fileIO.read(file.fd, new ArrayBuffer(4096), {
+ offset: 1,
+ length: FILE_CONTENT.length,
+ });
+ expect(readLen == FILE_CONTENT.length - 1).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_read_async_010 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_ASYNC_1100
+ * @tc.name fileIO_test_read_async_011
+ * @tc.desc Test read() interfaces. Callback.
+ * Open the file in read-only mode, reading the file with offset(position) = 1, length = 11.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_async_011', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_read_async_011');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.read(file.fd, new ArrayBuffer(4096), {
+ offset: 1,
+ length: FILE_CONTENT.length,
+ }, (err, readLen) => {
+ if(err) {
+ console.log('fileIO_test_read_async_011 err package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(readLen == FILE_CONTENT.length - 1).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_read_async_011 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_ASYNC_1200
+ * @tc.name fileIO_test_read_async_012
+ * @tc.desc Test read() interfaces. Promise.
+ * Read with invalid fd parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_async_012', 0, async function (done) {
+ try {
+ await fileIO.read(-1, new ArrayBuffer(4096));
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_read_async_012 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_ASYNC_1300
+ * @tc.name fileIO_test_read_async_013
+ * @tc.desc Test read() interfaces. Callback.
+ * Read with invalid fd parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_async_013', 0, async function (done) {
+ try {
+ fileIO.read(-1, new ArrayBuffer(4096), (err) => {
+ if(err) {
+ expect(false).assertTrue();
+ }
+ });
+ } catch (e) {
+ console.log('fileIO_test_read_async_013 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_ASYNC_1400
+ * @tc.name fileIO_test_read_async_014
+ * @tc.desc Test read() interfaces. Callback.
+ * Read with invalid offset < 0.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_async_014', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_read_async_014');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ const invalidOffset = -1;
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.read(file.fd, new ArrayBuffer(4096), {
+ offset: invalidOffset,
+ }, (err) => {
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_read_async_014 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_ASYNC_1500
+ * @tc.name fileIO_test_read_async_015
+ * @tc.desc Test read() interfaces. Callback.
+ * Read with invalid length > size of ArrayBuffer(4096).
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_async_015', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_read_async_015');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ const invalidLength = 4097;
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.read(file.fd, new ArrayBuffer(4096), {
+ length: invalidLength,
+ }, (err) => {
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_read_async_015 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_ASYNC_1600
+ * @tc.name fileIO_test_read_async_016
+ * @tc.desc Test read() interfaces. Promise.
+ * Open the file in read-only mode, reading the file with empty option.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_async_016', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_read_async_016');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readLen = await fileIO.read(file.fd, new ArrayBuffer(4096), {});
+ expect(readLen == FILE_CONTENT.length).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_read_async_016 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_ASYNC_1700
+ * @tc.name fileIO_test_read_async_017
+ * @tc.desc Test read() interfaces. Callback.
+ * Open the file in read-only mode, reading the file with empty option.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_async_017', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_read_async_017');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.read(file.fd, new ArrayBuffer(4096), {
+ }, (err, readLen) => {
+ if(err) {
+ console.log('fileIO_test_read_async_017 err package ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(readLen == FILE_CONTENT.length).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_read_async_017 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_ASYNC_1800
+ * @tc.name fileIO_test_read_async_018
+ * @tc.desc Test read() interfaces.
+ * Open the file in read-only mode, reading the file with length = -1(0 < length < buffer.size).
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_async_018', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_read_async_018');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ const invalidLength = -1;
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ await fileIO.read(file.fd, new ArrayBuffer(4096), {
+ length: invalidLength,
+ });
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_read_async_018 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_ASYNC_1900
+ * @tc.name fileIO_test_read_async_019
+ * @tc.desc Test read() interfaces.
+ * Verify that the Chinese, English, and symbols can be read correctly.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_async_019', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_read_async_019');
+ let CONTENT = ""
+ expect(prepareFile(fpath, CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let buf = new ArrayBuffer(4096);
+ await fileIO.read(file.fd, buf);
+ let textDecoder = new util.TextDecoder("utf-8", { ignoreBOM: true });
+ let resultPut = textDecoder.decodeWithStream(new Uint8Array(buf), { stream: true });
+ expect(resultPut == CONTENT).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_read_async_019 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_ASYNC_2000
+ * @tc.name fileIO_test_read_async_020
+ * @tc.desc Test read() interfaces. Promise.
+ * Undefined option arguments, use default options.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_async_020', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_test_read_async_020');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readLen1 = await fileIO.read(file.fd, new ArrayBuffer(16), undefined);
+ expect(readLen1 == FILE_CONTENT.length).assertTrue();
+ let readLen2 = await fileIO.read(file.fd, new ArrayBuffer(8), undefined);
+ expect(readLen2 == 0).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_read_async_020 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_ASYNC_2100
+ * @tc.name fileIO_test_read_async_021
+ * @tc.desc Test read() interfaces. Callback.
+ * Undefined option arguments, use default options.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_async_021', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_test_read_async_021');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.read(file.fd, new ArrayBuffer(16), undefined, (err, readlen1) => {
+ if(err) {
+ console.log('fileIO_test_read_async_021 err package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(readlen1 == FILE_CONTENT.length).assertTrue();
+ fileIO.read(file.fd, new ArrayBuffer(8), undefined, (err, readLen2) => {
+ if (err) {
+ console.log('fileIO_test_read_async_021 err package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(readLen2 == 0).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ });
+ } catch (e) {
+ console.log('fileIO_test_read_async_021 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_ASYNC_2200
+ * @tc.name fileIO_test_read_async_022
+ * @tc.desc Test read() interfaces. Promise.
+ * Undefined option arguments, use default options.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_async_022', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_test_read_async_022');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readLen1 = await fileIO.read(file.fd, new ArrayBuffer(4096), {
+ offset: undefined,
+ length: undefined,
+ });
+ expect(readLen1 == FILE_CONTENT.length).assertTrue();
+ let readLen2 = await fileIO.read(file.fd, new ArrayBuffer(8), {
+ offset: undefined,
+ length: undefined,
+ });
+ expect(readLen2 == 0).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_read_async_022 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_ASYNC_2300
+ * @tc.name fileIO_test_read_async_023
+ * @tc.desc Test read() interfaces. Callback.
+ * Undefined option arguments, use default options.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_read_async_023', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_test_read_async_023');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.read(file.fd, new ArrayBuffer(16), {
+ offset: undefined,
+ length: undefined,
+ }, (err, readLen1) => {
+ if(err) {
+ console.log('fileIO_test_read_async_011 err package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(readLen1 == FILE_CONTENT.length).assertTrue();
+ fileIO.read(file.fd, new ArrayBuffer(8), {
+ offset: undefined,
+ length: undefined,
+ }, (err, readLen2) => {
+ if (err) {
+ console.log('fileIO_test_read_async_001 err package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(readLen2 == 0).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ });
+ } catch (e) {
+ console.log('fileIO_test_read_async_023 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+});
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/readtext.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/readtext.test.js
similarity index 97%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/readtext.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/readtext.test.js
index 9d05a7a65811ad8e202259ec17f0bd6491a5c657..958550075bd05586e2aa254b9c2258f8f93dbad7 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/readtext.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/members/readtext.test.js
@@ -1,868 +1,868 @@
-/*
- * Copyright (C) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the 'License');
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an 'AS IS' BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import {
- fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect,
-} from '../Common';
-
-export default function fileIOReadtext() {
-describe('fileIO_fs_readtext', function () {
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_SYNC_0000
- * @tc.name fileIO_test_readtext_sync_000
- * @tc.desc Test readtextSync() interfaces.
- * Read file content by path, verify normal function.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_readtext_sync_000', 0, async function () {
- let fpath = await nextFileName('fileIO_test_readtext_sync_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let str = fileIO.readTextSync(fpath);
- expect(str == FILE_CONTENT).assertTrue();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_readtext_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_SYNC_0100
- * @tc.name fileIO_test_readtext_sync_001
- * @tc.desc Test readtextSync() interfaces.
- * str.substring(startIndex, [endIndex - 1]): Extracts and returns a string by index.
- * Read file content by path when offset = 1.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_sync_001', 0, async function () {
- let fpath = await nextFileName('fileIO_test_readtext_sync_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let str = fileIO.readTextSync(fpath, { offset: 1 });
- expect(str == FILE_CONTENT.substring(1, FILE_CONTENT.length + 1)).assertTrue();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_readtext_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_SYNC_0200
- * @tc.name fileIO_test_readtext_sync_002
- * @tc.desc Test readtextSync() interfaces.
- * Read file content by path when offset = 2, length = 4.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_sync_002', 0, async function () {
- let fpath = await nextFileName('fileIO_test_readtext_sync_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let str = fileIO.readTextSync(fpath, {
- offset: 2,
- length: 4
- });
- expect(str == FILE_CONTENT.substring(2, 6)).assertTrue();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_readtext_sync_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_SYNC_0300
- * @tc.name fileIO_test_readtext_sync_003
- * @tc.desc Test readtextSync() interfaces.
- * Read file content by path when offset = 1, length = 11, encoding = 'utf-8'.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_sync_003', 0, async function () {
- let fpath = await nextFileName('fileIO_test_readtext_sync_003');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let str = fileIO.readTextSync(fpath, {
- offset: 1,
- length: FILE_CONTENT.length,
- encoding: 'utf-8'
- });
- expect(str == FILE_CONTENT.substring(1, FILE_CONTENT.length + 1)).assertTrue();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_readtext_sync_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_SYNC_0400
- * @tc.name fileIO_test_readtext_sync_004
- * @tc.desc Test readtextSync() interfaces.
- * Missing parameter.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_sync_004', 0, async function () {
-
- try {
- fileIO.readTextSync();
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_readtext_sync_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_SYNC_0500
- * @tc.name fileIO_test_readtext_sync_005
- * @tc.desc Test readtextSync() interfaces.
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_sync_005', 0, async function () {
- let fpath = await nextFileName('fileIO_test_readtext_sync_005');
-
- try {
- fileIO.readTextSync(fpath);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_readtext_sync_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_SYNC_0600
- * @tc.name fileIO_test_readtext_sync_006
- * @tc.desc Test readtextSync() interfaces.
- * Read file content with invalid offset < 0.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_sync_006', 0, async function () {
- let fpath = await nextFileName('fileIO_test_readtext_sync_006');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- const invalidOffset = -1;
- fileIO.readTextSync(fpath, { offset: invalidOffset });
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_readtext_sync_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_SYNC_0700
- * @tc.name fileIO_test_readtext_sync_007
- * @tc.desc Test readtextSync() interfaces.
- * Read file content with invalid offset = 9999.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_sync_007', 0, async function () {
- let fpath = await nextFileName('fileIO_test_readtext_sync_007');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- const invalidOffset = 9999;
- fileIO.readTextSync(fpath, { offset: invalidOffset });
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_readtext_sync_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_SYNC_0800
- * @tc.name fileIO_test_readtext_sync_008
- * @tc.desc Test readtextSync() interfaces.
- * Read file content with invalid length < 0.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_sync_008', 0, async function () {
- let fpath = await nextFileName('fileIO_test_readtext_sync_008');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- const invalidLength = -1;
- fileIO.readTextSync(fpath, { length: invalidLength });
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_readtext_sync_008 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_SYNC_0900
- * @tc.name fileIO_test_readtext_sync_009
- * @tc.desc Test readtextSync() interfaces.
- * Use default option.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_sync_009', 3, async function () {
- let fpath = await nextFileName('fileIO_test_readtext_sync_009');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let str = fileIO.readTextSync(fpath, undefined);
- expect(str == FILE_CONTENT).assertTrue();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_readtext_sync_009 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_SYNC_1000
- * @tc.name fileIO_test_readtext_sync_010
- * @tc.desc Test readtextSync() interfaces.
- * Use default option.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_sync_010', 3, async function () {
- let fpath = await nextFileName('fileIO_test_readtext_sync_010');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let str = fileIO.readTextSync(fpath, {
- offset: undefined,
- length: undefined,
- encoding: undefined
- });
- expect(str == FILE_CONTENT).assertTrue();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_readtext_sync_010 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_0000
- * @tc.name fileIO_test_readtext_async_000
- * @tc.desc Test readtext() interfaces. Promise.
- * Read file content by path, verify normal function.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_readtext_async_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_readtext_async_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let str = await fileIO.readText(fpath);
- expect(str == FILE_CONTENT).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_readtext_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_0100
- * @tc.name fileIO_test_readtext_async_001
- * @tc.desc Test readtext() interfaces. Callback.
- * Read file content by path, verify normal function.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_readtext_async_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_readtext_async_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.readText(fpath, (err, str) => {
- if (err) {
- console.log('fileIO_test_readtext_async_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(str == FILE_CONTENT).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_readtext_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_0200
- * @tc.name fileIO_test_readtext_async_002
- * @tc.desc Test readtext() interfaces. Promise.
- * Read file content by path when offset = 1.
- * str.substr(startIndex, [length]): Extracts and returns a string by index and length of str.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_async_002', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_readtext_async_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let str = await fileIO.readText(fpath, { offset: 1 });
- expect(str == FILE_CONTENT.substr(1, FILE_CONTENT.length - 1)).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_readtext_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_0300
- * @tc.name fileIO_test_readtext_async_003
- * @tc.desc Test readtext() interfaces. Callback.
- * Read file content by path when offset = 1.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_async_003', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_readtext_async_003');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.readText(fpath, { offset: 1 }, (err, str) => {
- if (err) {
- console.log('fileIO_test_readtext_async_003 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(str == FILE_CONTENT.substr(1, FILE_CONTENT.length - 1)).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_readtext_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_0400
- * @tc.name fileIO_test_readtext_async_004
- * @tc.desc Test readtext() interfaces. Promise.
- * Read file content by path when offset = 1, length = 2.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_async_004', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_readtext_async_004');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let str = await fileIO.readText(fpath, {
- offset: 1,
- length: 2
- });
- expect(str == FILE_CONTENT.substr(1, 2)).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_readtext_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_0500
- * @tc.name fileIO_test_readtext_async_005
- * @tc.desc Test readtext() interfaces. Callback.
- * Read file content by path when offset = 1, length = 2.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_async_005', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_readtext_async_005');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.readText(fpath, {
- offset: 1,
- length: 2
- }, (err, str) => {
- if (err) {
- console.log('fileIO_test_readtext_async_005 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(str == FILE_CONTENT.substr(1, 2)).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_readtext_async_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_0600
- * @tc.name fileIO_test_readtext_async_006
- * @tc.desc Test readtext() interfaces. Promise.
- * Read file content by path when offset = 1, length = 11, encoding = 'utf-8'.
- * str.slice(startIndex, [endIndex - 1]): Extracts and returns a string by index.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_async_006', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_readtext_async_006');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let str = await fileIO.readText(fpath, {
- offset: 1,
- length: FILE_CONTENT.length,
- encoding: 'utf-8'
- });
- expect(str == FILE_CONTENT.slice(1, FILE_CONTENT.length + 1)).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_readtext_async_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_0700
- * @tc.name fileIO_test_readtext_async_007
- * @tc.desc Test readtext() interfaces. Promise.then().catch()
- * Read file content by path when offset = 1, length = 11, encoding = 'utf-8'.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_async_007', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_readtext_async_007');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.readText(fpath, {
- offset: 1,
- length: FILE_CONTENT.length,
- encoding: 'utf-8'
- }).then((str) => {
- expect(str == FILE_CONTENT.slice(1, FILE_CONTENT.length + 1)).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- }).catch((err) => {
- console.log('fileIO_test_readtext_async_007 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- });
- } catch (e) {
- console.log('fileIO_test_readtext_async_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_0800
- * @tc.name fileIO_test_readtext_async_008
- * @tc.desc Test readtext() interfaces. Callback.
- * Read file content by path when offset = 1, length = 11, encoding = 'utf-8'.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_async_008', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_readtext_async_008');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.readText(fpath, {
- offset: 1,
- length: FILE_CONTENT.length,
- encoding: 'utf-8'
- }, (err, str) => {
- if (err) {
- console.log('fileIO_test_readtext_async_008 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(str == FILE_CONTENT.slice(1, FILE_CONTENT.length + 1)).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_readtext_async_008 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_0900
- * @tc.name fileIO_test_readtext_async_009
- * @tc.desc Test readtext() interfaces. Promise.
- * Read file content by path when option parameter is empty.
- * str.slice(startIndex, [endIndex - 1]): Extracts and returns a string by index.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_async_009', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_readtext_async_009');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let str = await fileIO.readText(fpath, {});
- expect(str == FILE_CONTENT).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_readtext_async_009 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_1000
- * @tc.name fileIO_test_readtext_async_010
- * @tc.desc Test readtext() interfaces. Callback.
- * Read file content by path when option parameter is empty.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_async_010', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_readtext_async_010');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.readText(fpath, {}, (err, str) => {
- if (err) {
- console.log('fileIO_test_readtext_async_010 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(str == FILE_CONTENT).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_readtext_async_010 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_1100
- * @tc.name fileIO_test_readtext_async_011
- * @tc.desc Test readtext() interfaces. Promise.
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_async_011', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_readtext_async_011');
-
- try {
- await fileIO.readText(fpath);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_readtext_async_011 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_1200
- * @tc.name fileIO_test_readtext_async_012
- * @tc.desc Test readtext() interfaces. Callback.
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_async_012', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_readtext_async_012');
-
- try {
- fileIO.readText(fpath, (err) => {
- if (err) {
- console.log('fileIO_test_readtext_async_012 error: {message:' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('fileIO_test_readtext_async_012 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_1300
- * @tc.name fileIO_test_readtext_async_013
- * @tc.desc Test readtext() interfaces.
- * Read file content with invalid offset < 0.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_async_013', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_readtext_async_013');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- const invalidOffset = -1;
- await fileIO.readText(fpath, { offset: invalidOffset });
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_readtext_async_013 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_1400
- * @tc.name fileIO_test_readtext_async_014
- * @tc.desc Test readtext() interfaces.
- * Read file content with invalid offset = 9999.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_async_014', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_readtext_async_014');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- const invalidOffset = 9999;
- await fileIO.readText(fpath, { offset: invalidOffset });
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_readtext_async_014 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_1500
- * @tc.name fileIO_test_readtext_async_015
- * @tc.desc Test readtext() interfaces.
- * Read file content with invalid length < 0.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_async_015', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_readtext_async_015');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- const invalidLength = -1;
- await fileIO.readText(fpath, { length: invalidLength });
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_readtext_async_015 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_1600
- * @tc.name fileIO_test_readtext_async_016
- * @tc.desc Test readtext() interfaces. Promise.
- * Use default option.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_async_016', 3, async function (done) {
- let fpath = await nextFileName('fileIO_test_readtext_async_016');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let str = await fileIO.readText(fpath, undefined);
- expect(str == FILE_CONTENT).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_readtext_async_016 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_1700
- * @tc.name fileIO_test_readtext_async_017
- * @tc.desc Test readtext() interfaces. Callback.
- * Use default option.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_async_017', 3, async function (done) {
- let fpath = await nextFileName('fileIO_test_readtext_async_017');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.readText(fpath, undefined, (err, str) => {
- if (err) {
- console.log('fileIO_test_readtext_async_017 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(str == FILE_CONTENT).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_readtext_async_017 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_1800
- * @tc.name fileIO_test_readtext_async_018
- * @tc.desc Test readtext() interfaces. Promise.
- * Use default option.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_async_018', 3, async function (done) {
- let fpath = await nextFileName('fileIO_test_readtext_async_018');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let str = await fileIO.readText(fpath, {
- offset: undefined,
- length: undefined,
- encoding: undefined
- });
- expect(str == FILE_CONTENT).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_readtext_async_018 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_1900
- * @tc.name fileIO_test_readtext_async_019
- * @tc.desc Test readtext() interfaces. Callback.
- * Use default option.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_readtext_async_019', 3, async function (done) {
- let fpath = await nextFileName('fileIO_test_readtext_async_019');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.readText(fpath, {
- offset: undefined,
- length: undefined,
- encoding: undefined
- }, (err, str) => {
- if (err) {
- console.log('fileIO_test_readtext_async_019 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(str == FILE_CONTENT).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_readtext_async_019 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-});
-}
+/*
+ * Copyright (C) 2023 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import {
+ fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect,
+} from '../Common';
+
+export default function fileIOReadtext() {
+describe('fileIO_fs_readtext', function () {
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_SYNC_0000
+ * @tc.name fileIO_test_readtext_sync_000
+ * @tc.desc Test readtextSync() interfaces.
+ * Read file content by path, verify normal function.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_readtext_sync_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_readtext_sync_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let str = fileIO.readTextSync(fpath);
+ expect(str == FILE_CONTENT).assertTrue();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_readtext_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_SYNC_0100
+ * @tc.name fileIO_test_readtext_sync_001
+ * @tc.desc Test readtextSync() interfaces.
+ * str.substring(startIndex, [endIndex - 1]): Extracts and returns a string by index.
+ * Read file content by path when offset = 1.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_sync_001', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_readtext_sync_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let str = fileIO.readTextSync(fpath, { offset: 1 });
+ expect(str == FILE_CONTENT.substring(1, FILE_CONTENT.length + 1)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_readtext_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_SYNC_0200
+ * @tc.name fileIO_test_readtext_sync_002
+ * @tc.desc Test readtextSync() interfaces.
+ * Read file content by path when offset = 2, length = 4.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_sync_002', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_readtext_sync_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let str = fileIO.readTextSync(fpath, {
+ offset: 2,
+ length: 4
+ });
+ expect(str == FILE_CONTENT.substring(2, 6)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_readtext_sync_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_SYNC_0300
+ * @tc.name fileIO_test_readtext_sync_003
+ * @tc.desc Test readtextSync() interfaces.
+ * Read file content by path when offset = 1, length = 11, encoding = 'utf-8'.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_sync_003', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_readtext_sync_003');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let str = fileIO.readTextSync(fpath, {
+ offset: 1,
+ length: FILE_CONTENT.length,
+ encoding: 'utf-8'
+ });
+ expect(str == FILE_CONTENT.substring(1, FILE_CONTENT.length + 1)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_readtext_sync_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_SYNC_0400
+ * @tc.name fileIO_test_readtext_sync_004
+ * @tc.desc Test readtextSync() interfaces.
+ * Missing parameter.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_sync_004', 0, async function () {
+
+ try {
+ fileIO.readTextSync();
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_readtext_sync_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_SYNC_0500
+ * @tc.name fileIO_test_readtext_sync_005
+ * @tc.desc Test readtextSync() interfaces.
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_sync_005', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_readtext_sync_005');
+
+ try {
+ fileIO.readTextSync(fpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_readtext_sync_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_SYNC_0600
+ * @tc.name fileIO_test_readtext_sync_006
+ * @tc.desc Test readtextSync() interfaces.
+ * Read file content with invalid offset < 0.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_sync_006', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_readtext_sync_006');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ const invalidOffset = -1;
+ fileIO.readTextSync(fpath, { offset: invalidOffset });
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_readtext_sync_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_SYNC_0700
+ * @tc.name fileIO_test_readtext_sync_007
+ * @tc.desc Test readtextSync() interfaces.
+ * Read file content with invalid offset = 9999.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_sync_007', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_readtext_sync_007');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ const invalidOffset = 9999;
+ fileIO.readTextSync(fpath, { offset: invalidOffset });
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_readtext_sync_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_SYNC_0800
+ * @tc.name fileIO_test_readtext_sync_008
+ * @tc.desc Test readtextSync() interfaces.
+ * Read file content with invalid length < 0.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_sync_008', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_readtext_sync_008');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ const invalidLength = -1;
+ fileIO.readTextSync(fpath, { length: invalidLength });
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_readtext_sync_008 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_SYNC_0900
+ * @tc.name fileIO_test_readtext_sync_009
+ * @tc.desc Test readtextSync() interfaces.
+ * Use default option.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_sync_009', 3, async function () {
+ let fpath = await nextFileName('fileIO_test_readtext_sync_009');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let str = fileIO.readTextSync(fpath, undefined);
+ expect(str == FILE_CONTENT).assertTrue();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_readtext_sync_009 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_SYNC_1000
+ * @tc.name fileIO_test_readtext_sync_010
+ * @tc.desc Test readtextSync() interfaces.
+ * Use default option.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_sync_010', 3, async function () {
+ let fpath = await nextFileName('fileIO_test_readtext_sync_010');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let str = fileIO.readTextSync(fpath, {
+ offset: undefined,
+ length: undefined,
+ encoding: undefined
+ });
+ expect(str == FILE_CONTENT).assertTrue();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_readtext_sync_010 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_0000
+ * @tc.name fileIO_test_readtext_async_000
+ * @tc.desc Test readtext() interfaces. Promise.
+ * Read file content by path, verify normal function.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_readtext_async_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_readtext_async_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let str = await fileIO.readText(fpath);
+ expect(str == FILE_CONTENT).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_readtext_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_0100
+ * @tc.name fileIO_test_readtext_async_001
+ * @tc.desc Test readtext() interfaces. Callback.
+ * Read file content by path, verify normal function.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_readtext_async_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_readtext_async_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.readText(fpath, (err, str) => {
+ if (err) {
+ console.log('fileIO_test_readtext_async_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(str == FILE_CONTENT).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_readtext_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_0200
+ * @tc.name fileIO_test_readtext_async_002
+ * @tc.desc Test readtext() interfaces. Promise.
+ * Read file content by path when offset = 1.
+ * str.substr(startIndex, [length]): Extracts and returns a string by index and length of str.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_async_002', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_readtext_async_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let str = await fileIO.readText(fpath, { offset: 1 });
+ expect(str == FILE_CONTENT.substr(1, FILE_CONTENT.length - 1)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_readtext_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_0300
+ * @tc.name fileIO_test_readtext_async_003
+ * @tc.desc Test readtext() interfaces. Callback.
+ * Read file content by path when offset = 1.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_async_003', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_readtext_async_003');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.readText(fpath, { offset: 1 }, (err, str) => {
+ if (err) {
+ console.log('fileIO_test_readtext_async_003 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(str == FILE_CONTENT.substr(1, FILE_CONTENT.length - 1)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_readtext_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_0400
+ * @tc.name fileIO_test_readtext_async_004
+ * @tc.desc Test readtext() interfaces. Promise.
+ * Read file content by path when offset = 1, length = 2.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_async_004', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_readtext_async_004');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let str = await fileIO.readText(fpath, {
+ offset: 1,
+ length: 2
+ });
+ expect(str == FILE_CONTENT.substr(1, 2)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_readtext_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_0500
+ * @tc.name fileIO_test_readtext_async_005
+ * @tc.desc Test readtext() interfaces. Callback.
+ * Read file content by path when offset = 1, length = 2.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_async_005', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_readtext_async_005');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.readText(fpath, {
+ offset: 1,
+ length: 2
+ }, (err, str) => {
+ if (err) {
+ console.log('fileIO_test_readtext_async_005 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(str == FILE_CONTENT.substr(1, 2)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_readtext_async_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_0600
+ * @tc.name fileIO_test_readtext_async_006
+ * @tc.desc Test readtext() interfaces. Promise.
+ * Read file content by path when offset = 1, length = 11, encoding = 'utf-8'.
+ * str.slice(startIndex, [endIndex - 1]): Extracts and returns a string by index.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_async_006', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_readtext_async_006');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let str = await fileIO.readText(fpath, {
+ offset: 1,
+ length: FILE_CONTENT.length,
+ encoding: 'utf-8'
+ });
+ expect(str == FILE_CONTENT.slice(1, FILE_CONTENT.length + 1)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_readtext_async_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_0700
+ * @tc.name fileIO_test_readtext_async_007
+ * @tc.desc Test readtext() interfaces. Promise.then().catch()
+ * Read file content by path when offset = 1, length = 11, encoding = 'utf-8'.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_async_007', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_readtext_async_007');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.readText(fpath, {
+ offset: 1,
+ length: FILE_CONTENT.length,
+ encoding: 'utf-8'
+ }).then((str) => {
+ expect(str == FILE_CONTENT.slice(1, FILE_CONTENT.length + 1)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ }).catch((err) => {
+ console.log('fileIO_test_readtext_async_007 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ console.log('fileIO_test_readtext_async_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_0800
+ * @tc.name fileIO_test_readtext_async_008
+ * @tc.desc Test readtext() interfaces. Callback.
+ * Read file content by path when offset = 1, length = 11, encoding = 'utf-8'.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_async_008', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_readtext_async_008');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.readText(fpath, {
+ offset: 1,
+ length: FILE_CONTENT.length,
+ encoding: 'utf-8'
+ }, (err, str) => {
+ if (err) {
+ console.log('fileIO_test_readtext_async_008 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(str == FILE_CONTENT.slice(1, FILE_CONTENT.length + 1)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_readtext_async_008 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_0900
+ * @tc.name fileIO_test_readtext_async_009
+ * @tc.desc Test readtext() interfaces. Promise.
+ * Read file content by path when option parameter is empty.
+ * str.slice(startIndex, [endIndex - 1]): Extracts and returns a string by index.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_async_009', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_readtext_async_009');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let str = await fileIO.readText(fpath, {});
+ expect(str == FILE_CONTENT).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_readtext_async_009 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_1000
+ * @tc.name fileIO_test_readtext_async_010
+ * @tc.desc Test readtext() interfaces. Callback.
+ * Read file content by path when option parameter is empty.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_async_010', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_readtext_async_010');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.readText(fpath, {}, (err, str) => {
+ if (err) {
+ console.log('fileIO_test_readtext_async_010 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(str == FILE_CONTENT).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_readtext_async_010 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_1100
+ * @tc.name fileIO_test_readtext_async_011
+ * @tc.desc Test readtext() interfaces. Promise.
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_async_011', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_readtext_async_011');
+
+ try {
+ await fileIO.readText(fpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_readtext_async_011 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_1200
+ * @tc.name fileIO_test_readtext_async_012
+ * @tc.desc Test readtext() interfaces. Callback.
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_async_012', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_readtext_async_012');
+
+ try {
+ fileIO.readText(fpath, (err) => {
+ if (err) {
+ console.log('fileIO_test_readtext_async_012 error: {message:' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('fileIO_test_readtext_async_012 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_1300
+ * @tc.name fileIO_test_readtext_async_013
+ * @tc.desc Test readtext() interfaces.
+ * Read file content with invalid offset < 0.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_async_013', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_readtext_async_013');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ const invalidOffset = -1;
+ await fileIO.readText(fpath, { offset: invalidOffset });
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_readtext_async_013 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_1400
+ * @tc.name fileIO_test_readtext_async_014
+ * @tc.desc Test readtext() interfaces.
+ * Read file content with invalid offset = 9999.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_async_014', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_readtext_async_014');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ const invalidOffset = 9999;
+ await fileIO.readText(fpath, { offset: invalidOffset });
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_readtext_async_014 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_1500
+ * @tc.name fileIO_test_readtext_async_015
+ * @tc.desc Test readtext() interfaces.
+ * Read file content with invalid length < 0.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_async_015', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_readtext_async_015');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ const invalidLength = -1;
+ await fileIO.readText(fpath, { length: invalidLength });
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_readtext_async_015 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_1600
+ * @tc.name fileIO_test_readtext_async_016
+ * @tc.desc Test readtext() interfaces. Promise.
+ * Use default option.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_async_016', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_test_readtext_async_016');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let str = await fileIO.readText(fpath, undefined);
+ expect(str == FILE_CONTENT).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_readtext_async_016 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_1700
+ * @tc.name fileIO_test_readtext_async_017
+ * @tc.desc Test readtext() interfaces. Callback.
+ * Use default option.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_async_017', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_test_readtext_async_017');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.readText(fpath, undefined, (err, str) => {
+ if (err) {
+ console.log('fileIO_test_readtext_async_017 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(str == FILE_CONTENT).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_readtext_async_017 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_1800
+ * @tc.name fileIO_test_readtext_async_018
+ * @tc.desc Test readtext() interfaces. Promise.
+ * Use default option.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_async_018', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_test_readtext_async_018');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let str = await fileIO.readText(fpath, {
+ offset: undefined,
+ length: undefined,
+ encoding: undefined
+ });
+ expect(str == FILE_CONTENT).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_readtext_async_018 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_READ_TEXT_ASYNC_1900
+ * @tc.name fileIO_test_readtext_async_019
+ * @tc.desc Test readtext() interfaces. Callback.
+ * Use default option.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_readtext_async_019', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_test_readtext_async_019');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.readText(fpath, {
+ offset: undefined,
+ length: undefined,
+ encoding: undefined
+ }, (err, str) => {
+ if (err) {
+ console.log('fileIO_test_readtext_async_019 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(str == FILE_CONTENT).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_readtext_async_019 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+});
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/rename.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/rename.test.js
similarity index 97%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/rename.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/rename.test.js
index 01ee1a89feb6b9abc6e9785edf4dbc12510d9bfc..8c1863e816a4288ecc891e9861a0dd7ebcfbedfc 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/rename.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/members/rename.test.js
@@ -1,618 +1,618 @@
-/*
- * Copyright (C) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the 'License');
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an 'AS IS' BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import featureAbility from '@ohos.ability.featureAbility';
-import {
- fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect, randomString
-} from '../Common';
-
-export default function fileIORename() {
-describe('fileIO_fs_rename', function () {
-
- /**
- * @tc.number SUB_DF_FILEIO_RENAME_SYNC_0000
- * @tc.name fileIO_test_rename_sync_000
- * @tc.desc Test renameSync() interfaces.
- * Rename the file by path, verify the normal function.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_rename_sync_000', 0, async function () {
- let fpath = await nextFileName('fileIO_test_rename_sync_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let newf = fpath + 'test';
- fileIO.renameSync(fpath, newf);
- expect(fileIO.accessSync(newf)).assertTrue();
- fileIO.unlinkSync(newf);
- } catch (e) {
- console.log('fileIO_test_rename_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_RENAME_SYNC_0100
- * @tc.name fileIO_test_rename_sync_001
- * @tc.desc Test renameSync() interfaces.
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rename_sync_001', 0, async function () {
- let fpath = await nextFileName('fileIO_test_rename_sync_001');
-
- try {
- fileIO.renameSync(fpath, fpath + 'test');
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_rename_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_RENAME_SYNC_0200
- * @tc.name fileIO_test_rename_sync_002
- * @tc.desc Test renameSync() interfaces.
- * Missing parameter.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rename_sync_002', 0, async function () {
- let fpath = await nextFileName('fileIO_test_rename_sync_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.renameSync(fpath);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_rename_sync_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_RENAME_SYNC_0300
- * @tc.name fileIO_test_rename_sync_003
- * @tc.desc Test renameSync() interfaces.
- * Illegal second parameter.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rename_sync_003', 0, async function () {
- let fpath = await nextFileName('fileIO_test_rename_sync_003');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.renameSync(fpath, null);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_rename_sync_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_RENAME_SYNC_0400
- * @tc.name fileIO_test_rename_sync_004
- * @tc.desc Test renameSync() interfaces.
- * Illegal second parameter.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rename_sync_004', 0, async function () {
- let fpath = await nextFileName('fileIO_test_rename_sync_004');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.renameSync(fpath, undefined);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_rename_sync_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_RENAME_SYNC_0500
- * @tc.name fileIO_test_rename_sync_005
- * @tc.desc Test renameSync() interfaces.
- * Modify file names across directory.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rename_sync_005', 0, async function () {
- let dpath = await nextFileName('fileIO_test_rename_sync_005');
- let fpath = dpath + '/file_000';
- fileIO.mkdirSync(dpath);
- fileIO.mkdirSync(dpath + '/dir_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let newf = dpath + '/dir_000/newFileName';
- fileIO.renameSync(fpath, newf);
- fileIO.rmdirSync(dpath);
- } catch (e) {
- console.log('fileIO_test_rename_sync_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_RENAME_SYNC_0600
- * @tc.name fileIO_test_rename_sync_006
- * @tc.desc Test renameSync() interfaces.
- * The length of file name is too long.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rename_sync_006', 0, async function () {
- let fpath = await nextFileName('fileIO_test_rename_sync_006');
- let fpathTarget = fpath + randomString(250);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.renameSync(fpath, fpathTarget);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_rename_sync_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900030 && e.message == 'File name too long').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_RENAME_SYNC_0700
- * @tc.name fileIO_test_rename_sync_007
- * @tc.desc Test rename() interfaces.
- * Don't have permission to operate on the root directory.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rename_sync_007', 0, async function () {
-
- try {
- fileIO.renameSync('/data', '/data_new');
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_rename_sync_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900012 && e.message == 'Permission denied').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_RENAME_SYNC_0800
- * @tc.name fileIO_test_rename_sync_008
- * @tc.desc Test rename() interfaces.
- * Can't modify file names across devices.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rename_sync_008', 0, async function () {
- let dstDir = await featureAbility.getContext().getOrCreateDistributedDir();
- let fpath = await nextFileName('fileIO_test_rename_sync_008');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.renameSync(fpath, dstDir + '/data_new');
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_rename_sync_008 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900016 && e.message == 'Cross-device link').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_0000
- * @tc.name fileIO_test_rename_async_000
- * @tc.desc Test rename() interfaces. Promise.
- * Rename the file by path, verify the normal function.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rename_async_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_rename_async_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let newf = fpath + '123';
-
- try {
- await fileIO.rename(fpath, newf);
- expect(fileIO.accessSync(newf)).assertTrue();
- fileIO.unlinkSync(newf);
- done();
- } catch (e) {
- console.log('fileIO_test_rename_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_0100
- * @tc.name fileIO_test_rename_async_001
- * @tc.desc Test rename() interfaces. Callback.
- * Rename the file by path, verify the normal function.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rename_async_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_rename_async_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let newf = fpath + 'aaa';
-
- try {
- fileIO.rename(fpath, newf, (err) => {
- if (err) {
- console.log('fileIO_test_rename_async_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(fileIO.accessSync(newf)).assertTrue();
- fileIO.unlinkSync(newf);
- done();
- })
- } catch (e) {
- console.log('fileIO_test_rename_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_0200
- * @tc.name fileIO_test_rename_async_002
- * @tc.desc Test rename() interfaces. Promise.
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rename_async_002', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_rename_async_002');
-
- try {
- await fileIO.rename(fpath, fpath + 'bbb');
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_rename_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_0300
- * @tc.name fileIO_test_rename_async_003
- * @tc.desc Test rename() interfaces. Callback.
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rename_async_003', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_rename_async_003');
-
- try {
- fileIO.rename(fpath, fpath + 'bbb', (err) => {
- if (err) {
- console.log('fileIO_test_rename_async_003 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('fileIO_test_rename_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_0400
- * @tc.name fileIO_test_rename_async_004
- * @tc.desc Test rename() interfaces. Promise.
- * Missing parameter.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rename_async_004', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_rename_async_004');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- await fileIO.rename(fpath);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_rename_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_0500
- * @tc.name fileIO_test_rename_async_005
- * @tc.desc Test rename() interfaces. Promise.
- * Illegal second parameter.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rename_async_005', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_rename_async_005');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- await fileIO.rename(fpath, null);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_rename_async_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_0600
- * @tc.name fileIO_test_rename_async_006
- * @tc.desc Test rename() interfaces. Promise.
- * Illegal second parameter.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rename_async_006', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_rename_async_006');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- await fileIO.rename(fpath, undefined);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_rename_async_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_0700
- * @tc.name fileIO_test_rename_async_007
- * @tc.desc Test rename() interfaces. Promise.
- * Modify file names across directory.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rename_async_007', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_rename_async_007');
- let fpath = dpath + '/file_001';
- fileIO.mkdirSync(dpath);
- fileIO.mkdirSync(dpath + '/dir_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let newf = dpath + '/dir_001/newFileName';
- await fileIO.rename(fpath, newf);
- fileIO.rmdirSync(dpath);
- done();
- } catch (e) {
- console.log('fileIO_test_rename_async_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_0800
- * @tc.name fileIO_test_rename_async_008
- * @tc.desc Test rename() interfaces. Callback.
- * Modify file names across directory.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rename_async_008', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_rename_async_008');
- let fpath = dpath + '/file_002';
- fileIO.mkdirSync(dpath);
- fileIO.mkdirSync(dpath + '/dir_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let newf = dpath + '/dir_002/newFileName';
- fileIO.rename(fpath, newf, (err) => {
- if (err) {
- console.log('fileIO_test_rename_async_008 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- fileIO.rmdirSync(dpath);
- });
- done();
- } catch (e) {
- console.log('fileIO_test_rename_async_008 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_0900
- * @tc.name fileIO_test_rename_async_009
- * @tc.desc Test rename() interfaces. Promise
- * The length of file name is too long.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rename_async_009', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_rename_async_009');
- let fpathTarget = fpath + randomString(250);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- await fileIO.rename(fpath, fpathTarget);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_rename_async_009 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900030 && e.message == 'File name too long').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_1000
- * @tc.name fileIO_test_rename_async_010
- * @tc.desc Test rename() interfaces. Callback
- * The length of file name is too long.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rename_async_010', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_rename_async_010');
- let fpathTarget = fpath + randomString(250);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.rename(fpath, fpathTarget, (err) => {
- if (err) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_rename_async_010 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900030 && err.message == 'File name too long').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('fileIO_test_rename_async_010 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_1100
- * @tc.name fileIO_test_rename_async_011
- * @tc.desc Test rename() interfaces. Promise.
- * Don't have permission to operate on the root directory.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rename_async_011', 0, async function (done) {
-
- try {
- await fileIO.rename('/data', '/data_new');
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_rename_async_011 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900012 && e.message == 'Permission denied').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_1200
- * @tc.name fileIO_test_rename_async_012
- * @tc.desc Test rename() interfaces.
- * Can't modify file names across devices.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rename_async_012', 0, async function (done) {
- let dstDir = await featureAbility.getContext().getOrCreateDistributedDir();
- let fpath = await nextFileName('fileIO_test_rename_async_012');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- await fileIO.rename(fpath, dstDir + '/data_new');
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_rename_async_012 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900016 && e.message == 'Cross-device link').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_1300
- * @tc.name fileIO_test_rename_async_013
- * @tc.desc Test rename() interfaces.
- * Can't modify file names across devices.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rename_async_013', 0, async function (done) {
- let dstDir = await featureAbility.getContext().getOrCreateDistributedDir();
- let fpath = await nextFileName('fileIO_test_rename_async_013');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.rename(fpath, dstDir + '/data_new', (err) => {
- if (err) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_symlink_async_005 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900016 && err.message == 'Cross-device link').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('fileIO_test_rename_async_013 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-});
-}
+/*
+ * Copyright (C) 2023 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import featureAbility from '@ohos.ability.featureAbility';
+import {
+ fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect, randomString
+} from '../Common';
+
+export default function fileIORename() {
+describe('fileIO_fs_rename', function () {
+
+ /**
+ * @tc.number SUB_DF_FILEIO_RENAME_SYNC_0000
+ * @tc.name fileIO_test_rename_sync_000
+ * @tc.desc Test renameSync() interfaces.
+ * Rename the file by path, verify the normal function.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_rename_sync_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_rename_sync_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let newf = fpath + 'test';
+ fileIO.renameSync(fpath, newf);
+ expect(fileIO.accessSync(newf)).assertTrue();
+ fileIO.unlinkSync(newf);
+ } catch (e) {
+ console.log('fileIO_test_rename_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_RENAME_SYNC_0100
+ * @tc.name fileIO_test_rename_sync_001
+ * @tc.desc Test renameSync() interfaces.
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rename_sync_001', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_rename_sync_001');
+
+ try {
+ fileIO.renameSync(fpath, fpath + 'test');
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_rename_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_RENAME_SYNC_0200
+ * @tc.name fileIO_test_rename_sync_002
+ * @tc.desc Test renameSync() interfaces.
+ * Missing parameter.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rename_sync_002', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_rename_sync_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.renameSync(fpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_rename_sync_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_RENAME_SYNC_0300
+ * @tc.name fileIO_test_rename_sync_003
+ * @tc.desc Test renameSync() interfaces.
+ * Illegal second parameter.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rename_sync_003', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_rename_sync_003');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.renameSync(fpath, null);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_rename_sync_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_RENAME_SYNC_0400
+ * @tc.name fileIO_test_rename_sync_004
+ * @tc.desc Test renameSync() interfaces.
+ * Illegal second parameter.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rename_sync_004', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_rename_sync_004');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.renameSync(fpath, undefined);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_rename_sync_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_RENAME_SYNC_0500
+ * @tc.name fileIO_test_rename_sync_005
+ * @tc.desc Test renameSync() interfaces.
+ * Modify file names across directory.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rename_sync_005', 0, async function () {
+ let dpath = await nextFileName('fileIO_test_rename_sync_005');
+ let fpath = dpath + '/file_000';
+ fileIO.mkdirSync(dpath);
+ fileIO.mkdirSync(dpath + '/dir_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let newf = dpath + '/dir_000/newFileName';
+ fileIO.renameSync(fpath, newf);
+ fileIO.rmdirSync(dpath);
+ } catch (e) {
+ console.log('fileIO_test_rename_sync_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_RENAME_SYNC_0600
+ * @tc.name fileIO_test_rename_sync_006
+ * @tc.desc Test renameSync() interfaces.
+ * The length of file name is too long.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rename_sync_006', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_rename_sync_006');
+ let fpathTarget = fpath + randomString(250);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.renameSync(fpath, fpathTarget);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_rename_sync_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900030 && e.message == 'File name too long').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_RENAME_SYNC_0700
+ * @tc.name fileIO_test_rename_sync_007
+ * @tc.desc Test rename() interfaces.
+ * Don't have permission to operate on the root directory.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rename_sync_007', 0, async function () {
+
+ try {
+ fileIO.renameSync('/data', '/data_new');
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_rename_sync_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900012 && e.message == 'Permission denied').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_RENAME_SYNC_0800
+ * @tc.name fileIO_test_rename_sync_008
+ * @tc.desc Test rename() interfaces.
+ * Can't modify file names across devices.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rename_sync_008', 0, async function () {
+ let dstDir = await featureAbility.getContext().getOrCreateDistributedDir();
+ let fpath = await nextFileName('fileIO_test_rename_sync_008');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.renameSync(fpath, dstDir + '/data_new');
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_rename_sync_008 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900016 && e.message == 'Cross-device link').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_0000
+ * @tc.name fileIO_test_rename_async_000
+ * @tc.desc Test rename() interfaces. Promise.
+ * Rename the file by path, verify the normal function.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rename_async_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_rename_async_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let newf = fpath + '123';
+
+ try {
+ await fileIO.rename(fpath, newf);
+ expect(fileIO.accessSync(newf)).assertTrue();
+ fileIO.unlinkSync(newf);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_rename_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_0100
+ * @tc.name fileIO_test_rename_async_001
+ * @tc.desc Test rename() interfaces. Callback.
+ * Rename the file by path, verify the normal function.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rename_async_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_rename_async_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let newf = fpath + 'aaa';
+
+ try {
+ fileIO.rename(fpath, newf, (err) => {
+ if (err) {
+ console.log('fileIO_test_rename_async_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(fileIO.accessSync(newf)).assertTrue();
+ fileIO.unlinkSync(newf);
+ done();
+ })
+ } catch (e) {
+ console.log('fileIO_test_rename_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_0200
+ * @tc.name fileIO_test_rename_async_002
+ * @tc.desc Test rename() interfaces. Promise.
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rename_async_002', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_rename_async_002');
+
+ try {
+ await fileIO.rename(fpath, fpath + 'bbb');
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_rename_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_0300
+ * @tc.name fileIO_test_rename_async_003
+ * @tc.desc Test rename() interfaces. Callback.
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rename_async_003', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_rename_async_003');
+
+ try {
+ fileIO.rename(fpath, fpath + 'bbb', (err) => {
+ if (err) {
+ console.log('fileIO_test_rename_async_003 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('fileIO_test_rename_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_0400
+ * @tc.name fileIO_test_rename_async_004
+ * @tc.desc Test rename() interfaces. Promise.
+ * Missing parameter.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rename_async_004', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_rename_async_004');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ await fileIO.rename(fpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_rename_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_0500
+ * @tc.name fileIO_test_rename_async_005
+ * @tc.desc Test rename() interfaces. Promise.
+ * Illegal second parameter.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rename_async_005', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_rename_async_005');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ await fileIO.rename(fpath, null);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_rename_async_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_0600
+ * @tc.name fileIO_test_rename_async_006
+ * @tc.desc Test rename() interfaces. Promise.
+ * Illegal second parameter.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rename_async_006', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_rename_async_006');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ await fileIO.rename(fpath, undefined);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_rename_async_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_0700
+ * @tc.name fileIO_test_rename_async_007
+ * @tc.desc Test rename() interfaces. Promise.
+ * Modify file names across directory.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rename_async_007', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_rename_async_007');
+ let fpath = dpath + '/file_001';
+ fileIO.mkdirSync(dpath);
+ fileIO.mkdirSync(dpath + '/dir_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let newf = dpath + '/dir_001/newFileName';
+ await fileIO.rename(fpath, newf);
+ fileIO.rmdirSync(dpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_rename_async_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_0800
+ * @tc.name fileIO_test_rename_async_008
+ * @tc.desc Test rename() interfaces. Callback.
+ * Modify file names across directory.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rename_async_008', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_rename_async_008');
+ let fpath = dpath + '/file_002';
+ fileIO.mkdirSync(dpath);
+ fileIO.mkdirSync(dpath + '/dir_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let newf = dpath + '/dir_002/newFileName';
+ fileIO.rename(fpath, newf, (err) => {
+ if (err) {
+ console.log('fileIO_test_rename_async_008 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ fileIO.rmdirSync(dpath);
+ });
+ done();
+ } catch (e) {
+ console.log('fileIO_test_rename_async_008 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_0900
+ * @tc.name fileIO_test_rename_async_009
+ * @tc.desc Test rename() interfaces. Promise
+ * The length of file name is too long.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rename_async_009', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_rename_async_009');
+ let fpathTarget = fpath + randomString(250);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ await fileIO.rename(fpath, fpathTarget);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_rename_async_009 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900030 && e.message == 'File name too long').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_1000
+ * @tc.name fileIO_test_rename_async_010
+ * @tc.desc Test rename() interfaces. Callback
+ * The length of file name is too long.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rename_async_010', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_rename_async_010');
+ let fpathTarget = fpath + randomString(250);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.rename(fpath, fpathTarget, (err) => {
+ if (err) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_rename_async_010 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900030 && err.message == 'File name too long').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('fileIO_test_rename_async_010 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_1100
+ * @tc.name fileIO_test_rename_async_011
+ * @tc.desc Test rename() interfaces. Promise.
+ * Don't have permission to operate on the root directory.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rename_async_011', 0, async function (done) {
+
+ try {
+ await fileIO.rename('/data', '/data_new');
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_rename_async_011 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900012 && e.message == 'Permission denied').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_1200
+ * @tc.name fileIO_test_rename_async_012
+ * @tc.desc Test rename() interfaces.
+ * Can't modify file names across devices.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rename_async_012', 0, async function (done) {
+ let dstDir = await featureAbility.getContext().getOrCreateDistributedDir();
+ let fpath = await nextFileName('fileIO_test_rename_async_012');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ await fileIO.rename(fpath, dstDir + '/data_new');
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_rename_async_012 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900016 && e.message == 'Cross-device link').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_RENAME_ASYNC_1300
+ * @tc.name fileIO_test_rename_async_013
+ * @tc.desc Test rename() interfaces.
+ * Can't modify file names across devices.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rename_async_013', 0, async function (done) {
+ let dstDir = await featureAbility.getContext().getOrCreateDistributedDir();
+ let fpath = await nextFileName('fileIO_test_rename_async_013');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.rename(fpath, dstDir + '/data_new', (err) => {
+ if (err) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_symlink_async_005 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900016 && err.message == 'Cross-device link').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('fileIO_test_rename_async_013 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+});
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/rmdir.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/rmdir.test.js
similarity index 97%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/rmdir.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/rmdir.test.js
index 77944038e99732209cd4a07bd89f88b0e375c824..e06a3ab1e76dfdbc650172602415a45763dd9567 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/rmdir.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/members/rmdir.test.js
@@ -1,346 +1,346 @@
-/*
- * Copyright (C) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the 'License');
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an 'AS IS' BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import {
- fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect,
-} from '../Common';
-
-export default function fileIORmdir() {
-describe('fileIO_fs_rmdir', function () {
-
- /**
- * @tc.number SUB_STORAGE_FILEIO_RMDIR_SYNC_0000
- * @tc.name fileIO_test_rmdir_sync_000
- * @tc.desc Test rmdirSync() interface.
- * Recursively delete all files and subfolders in a directory.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_rmdir_sync_000', 0, async function () {
- let dpath = await nextFileName('fileIO_test_rmdir_sync_000') + 'd';
- let fpath = dpath + '/rmdir_sync_000';
- let ffpath = dpath + '/rmdir_sync_000_1';
- let ddpath = dpath + '/rmdir_sync_000_1d';
- let fffpath = ddpath + '/rmdir_sync_000';
- fileIO.mkdirSync(dpath);
- fileIO.mkdirSync(ddpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- expect(prepareFile(ffpath, FILE_CONTENT)).assertTrue();
- expect(prepareFile(fffpath, FILE_CONTENT)).assertTrue();
-
- try {
- expect(fileIO.accessSync(ddpath)).assertTrue();
- expect(fileIO.accessSync(fffpath)).assertTrue();
- fileIO.rmdirSync(dpath);
- expect(!fileIO.accessSync(dpath)).assertTrue();
- expect(!fileIO.accessSync(ddpath)).assertTrue();
- expect(!fileIO.accessSync(fffpath)).assertTrue();
- } catch (e) {
- console.log('fileIO_test_rmdir_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
-});
-
- /**
- * @tc.number SUB_STORAGE_FILEIO_RMDIR_SYNC_0100
- * @tc.name fileIO_test_rmdir_sync_001
- * @tc.desc Test rmdirSync() interface.
- * Invalid path.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rmdir_sync_001', 0, async function () {
- let dpath = await nextFileName('fileIO_test_rmdir_sync_001') + 'd';
-
- try {
- fileIO.rmdirSync(dpath);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_rmdir_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_STORAGE_FILEIO_RMDIR_SYNC_0200
- * @tc.name fileIO_test_rmdir_sync_002
- * @tc.desc Test rmdirSync() interface.
- * Missing parameters.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rmdir_sync_002', 0, async function () {
-
- try {
- fileIO.rmdirSync();
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_rmdir_sync_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_STORAGE_FILEIO_RMDIR_SYNC_0300
- * @tc.name fileIO_test_rmdir_sync_003
- * @tc.desc Test rmdirSync() interface.
- * Invalid type of parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rmdir_sync_003', 0, function () {
-
- try {
- fileIO.rmdirSync(12);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_rmdir_sync_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_STORAGE_FILEIO_RMDIR_SYNC_0400
- * @tc.name fileIO_test_rmdir_sync_004
- * @tc.desc Test rmdirSync() interface.
- * The path contains ../, normal call.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rmdir_sync_004', 0, async function () {
- let dpath = await nextFileName('../cache/fileIO_test_rmdir_sync_003') + 'd';
-
- try {
- fileIO.mkdirSync(dpath);
- expect(fileIO.accessSync(dpath)).assertTrue();
- fileIO.rmdirSync(dpath);
- expect(!fileIO.accessSync(dpath)).assertTrue();
- } catch (e) {
- console.log('fileIO_test_rmdir_sync_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_STORAGE_FILEIO_RMDIR_ASYNC_0000
- * @tc.name fileIO_test_rmdir_async_000
- * @tc.desc Test rmdir() interface. Promise.
- * Recursively delete all files and subfolders in a directory.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rmdir_async_000', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_rmdir_async_000') + 'd';
- let fpath = dpath + '/rmdir_async_000';
- let ffpath = dpath + '/rmdir_async_000_1';
- let ddpath = dpath + '/rmdir_async_000_1d';
- let fffpath = ddpath + '/rmdir_async_000_2';
- fileIO.mkdirSync(dpath);
- fileIO.mkdirSync(ddpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- expect(prepareFile(ffpath, FILE_CONTENT)).assertTrue();
- expect(prepareFile(fffpath, FILE_CONTENT)).assertTrue();
-
- try {
- expect(fileIO.accessSync(ddpath)).assertTrue();
- expect(fileIO.accessSync(fffpath)).assertTrue();
- await fileIO.rmdir(dpath);
- expect(!fileIO.accessSync(dpath)).assertTrue();
- expect(!fileIO.accessSync(ddpath)).assertTrue();
- expect(!fileIO.accessSync(fffpath)).assertTrue();
- done();
- } catch (e) {
- console.log('fileIO_test_rmdir_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_STORAGE_FILEIO_RMDIR_ASYNC_0100
- * @tc.name fileIO_test_rmdir_async_001
- * @tc.desc Test rmdir() interface. Callback.
- * Recursively delete all files and subfolders in a directory.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rmdir_async_001', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_rmdir_async_001') + 'd';
- let fpath = dpath + '/rmdir_async_001';
- let ffpath = dpath + '/rmdir_async_001_1';
- let ddpath = dpath + '/rmdir_async_001_1d';
- let fffpath = ddpath + '/rmdir_async_001_2';
- fileIO.mkdirSync(dpath);
- fileIO.mkdirSync(ddpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- expect(prepareFile(ffpath, FILE_CONTENT)).assertTrue();
- expect(prepareFile(fffpath, FILE_CONTENT)).assertTrue();
-
- try {
- expect(fileIO.accessSync(ddpath)).assertTrue();
- expect(fileIO.accessSync(fffpath)).assertTrue();
- fileIO.rmdir(dpath, (err) => {
- if(err) {
- console.log('fileIO_test_rmdir_async_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(!fileIO.accessSync(dpath)).assertTrue();
- expect(!fileIO.accessSync(ddpath)).assertTrue();
- expect(!fileIO.accessSync(fffpath)).assertTrue();
- done();
- });
- } catch (e) {
- console.log('fileIO_test_rmdir_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_STORAGE_FILEIO_RMDIR_ASYNC_0200
- * @tc.name fileIO_test_rmdir_async_002
- * @tc.desc Test rmdir() interface. Promise.
- * Invalid path.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rmdir_async_002', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_rmdir_async_002') + 'd';
-
- try {
- await fileIO.rmdir(dpath);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_rmdir_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_STORAGE_FILEIO_RMDIR_ASYNC_0300
- * @tc.name fileIO_test_rmdir_async_003
- * @tc.desc Test rmdir() interface. Callback.
- * Invalid path.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rmdir_async_003', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_rmdir_async_003') + 'd';
-
- try {
- fileIO.rmdir(dpath, (err) => {
- if (err) {
- console.log('fileIO_test_rmdir_async_003 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('fileIO_test_rmdir_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_STORAGE_FILEIO_RMDIR_ASYNC_0400
- * @tc.name fileIO_test_rmdir_async_004
- * @tc.desc Test rmdir() interface. Callback.
- * Parameter mismatch.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rmdir_async_004', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_rmdir_async_004') + 'd';
-
- try {
- fileIO.mkdirSync(dpath);
- expect(fileIO.accessSync(dpath)).assertTrue();
- fileIO.rmdir(dpath, '', (err) => {
- expect(false).assertTrue();
- });
- } catch (e) {
- fileIO.rmdirSync(dpath);
- console.log('fileIO_test_rmdir_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_STORAGE_FILEIO_RMDIR_ASYNC_0500
- * @tc.name fileIO_test_rmdir_async_005
- * @tc.desc Test rmdir() interfaces. Promise.
- * Missing parameter.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rmdir_async_005', 0, async function (done) {
-
- try {
- await fileIO.rmdir();
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_rmdir_async_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_STORAGE_FILEIO_RMDIR_ASYNC_0600
- * @tc.name fileIO_test_rmdir_async_006
- * @tc.desc Test rmdirSync() interface. Promise.
- * The path contains ../, normal call.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_rmdir_async_006', 0, async function () {
- let dpath = await nextFileName('../cache/fileIO_test_rmdir_async_006') + 'd';
-
- try {
- fileIO.mkdirSync(dpath);
- expect(fileIO.accessSync(dpath)).assertTrue();
- await fileIO.rmdir(dpath);
- expect(!fileIO.accessSync(dpath)).assertTrue();
- } catch (e) {
- console.log('fileIO_test_rmdir_async_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-})
+/*
+ * Copyright (C) 2023 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import {
+ fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect,
+} from '../Common';
+
+export default function fileIORmdir() {
+describe('fileIO_fs_rmdir', function () {
+
+ /**
+ * @tc.number SUB_STORAGE_FILEIO_RMDIR_SYNC_0000
+ * @tc.name fileIO_test_rmdir_sync_000
+ * @tc.desc Test rmdirSync() interface.
+ * Recursively delete all files and subfolders in a directory.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_rmdir_sync_000', 0, async function () {
+ let dpath = await nextFileName('fileIO_test_rmdir_sync_000') + 'd';
+ let fpath = dpath + '/rmdir_sync_000';
+ let ffpath = dpath + '/rmdir_sync_000_1';
+ let ddpath = dpath + '/rmdir_sync_000_1d';
+ let fffpath = ddpath + '/rmdir_sync_000';
+ fileIO.mkdirSync(dpath);
+ fileIO.mkdirSync(ddpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ expect(prepareFile(ffpath, FILE_CONTENT)).assertTrue();
+ expect(prepareFile(fffpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ expect(fileIO.accessSync(ddpath)).assertTrue();
+ expect(fileIO.accessSync(fffpath)).assertTrue();
+ fileIO.rmdirSync(dpath);
+ expect(!fileIO.accessSync(dpath)).assertTrue();
+ expect(!fileIO.accessSync(ddpath)).assertTrue();
+ expect(!fileIO.accessSync(fffpath)).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_rmdir_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+});
+
+ /**
+ * @tc.number SUB_STORAGE_FILEIO_RMDIR_SYNC_0100
+ * @tc.name fileIO_test_rmdir_sync_001
+ * @tc.desc Test rmdirSync() interface.
+ * Invalid path.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rmdir_sync_001', 0, async function () {
+ let dpath = await nextFileName('fileIO_test_rmdir_sync_001') + 'd';
+
+ try {
+ fileIO.rmdirSync(dpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_rmdir_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_FILEIO_RMDIR_SYNC_0200
+ * @tc.name fileIO_test_rmdir_sync_002
+ * @tc.desc Test rmdirSync() interface.
+ * Missing parameters.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rmdir_sync_002', 0, async function () {
+
+ try {
+ fileIO.rmdirSync();
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_rmdir_sync_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_FILEIO_RMDIR_SYNC_0300
+ * @tc.name fileIO_test_rmdir_sync_003
+ * @tc.desc Test rmdirSync() interface.
+ * Invalid type of parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rmdir_sync_003', 0, function () {
+
+ try {
+ fileIO.rmdirSync(12);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_rmdir_sync_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_FILEIO_RMDIR_SYNC_0400
+ * @tc.name fileIO_test_rmdir_sync_004
+ * @tc.desc Test rmdirSync() interface.
+ * The path contains ../, normal call.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rmdir_sync_004', 0, async function () {
+ let dpath = await nextFileName('../cache/fileIO_test_rmdir_sync_003') + 'd';
+
+ try {
+ fileIO.mkdirSync(dpath);
+ expect(fileIO.accessSync(dpath)).assertTrue();
+ fileIO.rmdirSync(dpath);
+ expect(!fileIO.accessSync(dpath)).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_rmdir_sync_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_FILEIO_RMDIR_ASYNC_0000
+ * @tc.name fileIO_test_rmdir_async_000
+ * @tc.desc Test rmdir() interface. Promise.
+ * Recursively delete all files and subfolders in a directory.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rmdir_async_000', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_rmdir_async_000') + 'd';
+ let fpath = dpath + '/rmdir_async_000';
+ let ffpath = dpath + '/rmdir_async_000_1';
+ let ddpath = dpath + '/rmdir_async_000_1d';
+ let fffpath = ddpath + '/rmdir_async_000_2';
+ fileIO.mkdirSync(dpath);
+ fileIO.mkdirSync(ddpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ expect(prepareFile(ffpath, FILE_CONTENT)).assertTrue();
+ expect(prepareFile(fffpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ expect(fileIO.accessSync(ddpath)).assertTrue();
+ expect(fileIO.accessSync(fffpath)).assertTrue();
+ await fileIO.rmdir(dpath);
+ expect(!fileIO.accessSync(dpath)).assertTrue();
+ expect(!fileIO.accessSync(ddpath)).assertTrue();
+ expect(!fileIO.accessSync(fffpath)).assertTrue();
+ done();
+ } catch (e) {
+ console.log('fileIO_test_rmdir_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_FILEIO_RMDIR_ASYNC_0100
+ * @tc.name fileIO_test_rmdir_async_001
+ * @tc.desc Test rmdir() interface. Callback.
+ * Recursively delete all files and subfolders in a directory.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rmdir_async_001', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_rmdir_async_001') + 'd';
+ let fpath = dpath + '/rmdir_async_001';
+ let ffpath = dpath + '/rmdir_async_001_1';
+ let ddpath = dpath + '/rmdir_async_001_1d';
+ let fffpath = ddpath + '/rmdir_async_001_2';
+ fileIO.mkdirSync(dpath);
+ fileIO.mkdirSync(ddpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ expect(prepareFile(ffpath, FILE_CONTENT)).assertTrue();
+ expect(prepareFile(fffpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ expect(fileIO.accessSync(ddpath)).assertTrue();
+ expect(fileIO.accessSync(fffpath)).assertTrue();
+ fileIO.rmdir(dpath, (err) => {
+ if(err) {
+ console.log('fileIO_test_rmdir_async_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(!fileIO.accessSync(dpath)).assertTrue();
+ expect(!fileIO.accessSync(ddpath)).assertTrue();
+ expect(!fileIO.accessSync(fffpath)).assertTrue();
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_rmdir_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_FILEIO_RMDIR_ASYNC_0200
+ * @tc.name fileIO_test_rmdir_async_002
+ * @tc.desc Test rmdir() interface. Promise.
+ * Invalid path.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rmdir_async_002', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_rmdir_async_002') + 'd';
+
+ try {
+ await fileIO.rmdir(dpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_rmdir_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_FILEIO_RMDIR_ASYNC_0300
+ * @tc.name fileIO_test_rmdir_async_003
+ * @tc.desc Test rmdir() interface. Callback.
+ * Invalid path.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rmdir_async_003', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_rmdir_async_003') + 'd';
+
+ try {
+ fileIO.rmdir(dpath, (err) => {
+ if (err) {
+ console.log('fileIO_test_rmdir_async_003 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('fileIO_test_rmdir_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_FILEIO_RMDIR_ASYNC_0400
+ * @tc.name fileIO_test_rmdir_async_004
+ * @tc.desc Test rmdir() interface. Callback.
+ * Parameter mismatch.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rmdir_async_004', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_rmdir_async_004') + 'd';
+
+ try {
+ fileIO.mkdirSync(dpath);
+ expect(fileIO.accessSync(dpath)).assertTrue();
+ fileIO.rmdir(dpath, '', (err) => {
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ fileIO.rmdirSync(dpath);
+ console.log('fileIO_test_rmdir_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_FILEIO_RMDIR_ASYNC_0500
+ * @tc.name fileIO_test_rmdir_async_005
+ * @tc.desc Test rmdir() interfaces. Promise.
+ * Missing parameter.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rmdir_async_005', 0, async function (done) {
+
+ try {
+ await fileIO.rmdir();
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_rmdir_async_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_FILEIO_RMDIR_ASYNC_0600
+ * @tc.name fileIO_test_rmdir_async_006
+ * @tc.desc Test rmdirSync() interface. Promise.
+ * The path contains ../, normal call.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_rmdir_async_006', 0, async function () {
+ let dpath = await nextFileName('../cache/fileIO_test_rmdir_async_006') + 'd';
+
+ try {
+ fileIO.mkdirSync(dpath);
+ expect(fileIO.accessSync(dpath)).assertTrue();
+ await fileIO.rmdir(dpath);
+ expect(!fileIO.accessSync(dpath)).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_rmdir_async_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+})
}
\ No newline at end of file
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/stat.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/stat.test.js
similarity index 97%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/stat.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/stat.test.js
index 7299a464aaa198fa06fb5062565d33b3f5cdd851..057a4471952f4bedfe76e0b44ed95c66c33f8a11 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/stat.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/members/stat.test.js
@@ -1,2316 +1,2316 @@
-/*
- * Copyright (C) 2022 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the 'License');
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an 'AS IS' BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import {
- fileIO, FILE_CONTENT, prepareFile, nextFileName, isIntNum, isBigInt,
- describe, it, expect,
- } from '../Common';
-
-export default function fileIOStat() {
-describe('fileIO_fs_stat', function () {
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_0000
- * @tc.name fileIO_stat_sync_000
- * @tc.desc Test statSync() interfaces.
- * Enter the path or fd parameter to get the file stat.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_stat_sync_000', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.statSync(fpath);
- expect(stat !== null).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = fileIO.statSync(file.fd);
- expect(stat2 !== null).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_stat_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_0100
- * @tc.name fileIO_stat_sync_001
- * @tc.desc Test statSync() interfaces.
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_001', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_001');
-
- try {
- fileIO.statSync(fpath);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_stat_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_0200
- * @tc.name fileIO_stat_sync_002
- * @tc.desc Test statSync() interfaces. Missing parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_002', 0, async function () {
-
- try {
- fileIO.statSync();
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_stat_sync_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_INO_0000
- * @tc.name fileIO_stat_sync_ino_000
- * @tc.desc Test the ino member of class Stat.
- * Enter the path or fd parameter to get stat.ino of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_ino_000', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_ino_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.statSync(fpath);
- expect(isBigInt(stat.ino)).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = fileIO.statSync(file.fd);
- expect(isBigInt(stat2.ino)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_stat_sync_ino_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_MODE_0000
- * @tc.name fileIO_stat_sync_mode_000
- * @tc.desc Test the mode member of class Stat.
- * Enter the path or fd parameter to get stat.mode of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_mode_000', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_mode_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.statSync(fpath);
- expect(isIntNum(stat.mode)).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = fileIO.statSync(file.fd);
- expect(isIntNum(stat2.mode)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_stat_sync_mode_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_UID_0000
- * @tc.name fileIO_stat_sync_uid_000
- * @tc.desc Test the uid member of class Stat.
- * Enter the path or fd parameter to get stat.uid of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_uid_000', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_uid_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.statSync(fpath);
- expect(isIntNum(stat.uid)).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = fileIO.statSync(file.fd);
- expect(isIntNum(stat2.uid)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_stat_sync_uid_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_GID_0000
- * @tc.name fileIO_stat_sync_gid_000
- * @tc.desc Test the gid member of class Stat.
- * Enter the path or fd parameter to get stat.gid of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_gid_000', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_gid_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.statSync(fpath);
- expect(isIntNum(stat.gid)).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = fileIO.statSync(file.fd);
- expect(isIntNum(stat2.gid)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_stat_sync_gid_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_SIZE_0000
- * @tc.name fileIO_stat_sync_size_000
- * @tc.desc Test the size member of class Stat.
- * Enter the path or fd parameter to get stat.size of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_size_000', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_size_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.statSync(fpath);
- expect(isIntNum(stat.size)).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = fileIO.statSync(file.fd);
- expect(isIntNum(stat2.size)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_stat_sync_size_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_ATIME_0000
- * @tc.name fileIO_stat_sync_atime_000
- * @tc.desc Test the atime member of class Stat.
- * Enter the path or fd parameter to get stat.atime of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_atime_000', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_atime_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.statSync(fpath);
- expect(isIntNum(stat.atime)).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = fileIO.statSync(file.fd);
- expect(isIntNum(stat2.atime)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_stat_sync_atime_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_MTIME_0000
- * @tc.name fileIO_stat_sync_mtime_000
- * @tc.desc Test the mtime member of class Stat.
- * Enter the path or fd parameter to get stat.mtime of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_mtime_000', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_mtime_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.statSync(fpath);
- expect(isIntNum(stat.mtime)).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = fileIO.statSync(file.fd);
- expect(isIntNum(stat2.mtime)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_stat_sync_mtime_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_CTIME_0000
- * @tc.name fileIO_stat_sync_ctime_000
- * @tc.desc Test the ctime member of class Stat.
- * Enter the path or fd parameter to get stat.ctime of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_ctime_000', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_ctime_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.statSync(fpath);
- expect(isIntNum(stat.ctime)).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = fileIO.statSync(file.fd);
- expect(isIntNum(stat2.ctime)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_stat_sync_ctime_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISBLOCKDEVICE_0000
- * @tc.name fileIO_stat_sync_is_block_device_000
- * @tc.desc Test the isBlockDevice() method of class Stat.
- * This interface shall not treat a normal file as a block special device.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_is_block_device_000', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_is_block_device_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.statSync(fpath);
- expect(stat.isBlockDevice() === false).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = fileIO.statSync(file.fd);
- expect(stat2.isBlockDevice() === false).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_stat_sync_is_block_device_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISBLOCKDEVICE_0100
- * @tc.name fileIO_stat_sync_is_block_device_001
- * @tc.desc Test the isBlockDevice() method of class Stat.
- * This interface does not require parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_is_block_device_001', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_is_block_device_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.statSync(fpath).isBlockDevice(-1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_stat_sync_is_block_device_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISBLOCKDEVICE_0200
- * @tc.name fileIO_stat_sync_is_block_device_002
- * @tc.desc Test the isBlockDevice() method of class Stat.
- * This interface does not require parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_is_block_device_002', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_is_block_device_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath);
-
- try {
- fileIO.statSync(file.fd).isBlockDevice(-1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_stat_sync_is_block_device_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
-
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISCHARACTER_DEVICE_0000
- * @tc.name fileIO_stat_sync_is_character_device_000
- * @tc.desc Test the isCharacterDevice() method of class Stat.
- * This interface shall not treat a normal file as a character special device.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_is_character_device_000', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_is_character_device_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.statSync(fpath);
- expect(stat.isCharacterDevice() === false).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = fileIO.statSync(file.fd);
- expect(stat2.isCharacterDevice() === false).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_stat_sync_is_character_device_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISCHARACTER_DEVICE_0100
- * @tc.name fileIO_stat_sync_is_character_device_001
- * @tc.desc Test the isCharacterDevice() method of class Stat.
- * This interface does not require parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_is_character_device_001', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_is_character_device_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.statSync(fpath).isCharacterDevice(-1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_stat_sync_is_character_device_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISCHARACTER_DEVICE_0200
- * @tc.name fileIO_stat_sync_is_character_device_002
- * @tc.desc Test the isCharacterDevice() method of class Stat.
- * This interface does not require parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_is_character_device_002', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_is_character_device_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath);
-
- try {
- fileIO.statSync(file.fd).isCharacterDevice(-1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_stat_sync_is_character_device_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISDIRECTORY_0000
- * @tc.name fileIO_stat_sync_is_directory_000
- * @tc.desc Test the isDirectory() method of class Stat.
- * This interface shall not treat a normal file as a directory.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_is_directory_000', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_is_directory_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.statSync(fpath);
- expect(stat.isDirectory() === false).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = fileIO.statSync(file.fd);
- expect(stat2.isDirectory() === false).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_stat_sync_is_directory_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISDIRECTORY_0100
- * @tc.name fileIO_stat_sync_is_directory_001
- * @tc.desc Test the isDirectory() method of class Stat.
- * This interface shall treat a directory as a directory.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_is_directory_001', 0, async function () {
- let dpath = await nextFileName('fileIO_stat_sync_is_directory_001');
-
- try {
- fileIO.mkdirSync(dpath);
- let stat = fileIO.statSync(dpath);
- expect(stat.isDirectory() === true).assertTrue();
-
- let file = fileIO.openSync(dpath, fileIO.OpenMode.DIR);
- let stat2 = fileIO.statSync(file.fd);
- expect(stat2.isDirectory() === true).assertTrue();
- fileIO.closeSync(file);
- fileIO.rmdirSync(dpath);
- } catch (e) {
- console.log('fileIO_stat_sync_is_directory_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISDIRECTORY_0200
- * @tc.name fileIO_stat_sync_is_directory_002
- * @tc.desc Test the isDirectory() method of class Stat.
- * This interface does not require parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_is_directory_002', 0, async function () {
- let dpath = await nextFileName('fileIO_stat_sync_is_directory_002') + 'd';
-
- try {
- fileIO.mkdirSync(dpath);
- fileIO.statSync(dpath).isDirectory(-1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.rmdirSync(dpath);
- console.log('fileIO_stat_sync_is_directory_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISDIRECTORY_0300
- * @tc.name fileIO_stat_sync_is_directory_003
- * @tc.desc Test the isDirectory() method of class Stat.
- * This interface does not require parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_is_directory_003', 0, async function () {
- let dpath = await nextFileName('fileIO_stat_sync_is_directory_003') + 'd';
- fileIO.mkdirSync(dpath);
- let file = fileIO.openSync(dpath, fileIO.OpenMode.DIR);
-
- try {
- fileIO.statSync(file.fd).isDirectory(-1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.rmdirSync(dpath);
- console.log('fileIO_stat_sync_is_directory_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISFIFO_0000
- * @tc.name fileIO_stat_sync_is_fifo_000
- * @tc.desc Test the isFIFO() method of class Stat.
- * This interface shall not treat a normal file as a FIFO.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_is_fifo_000', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_is_fifo_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.statSync(fpath);
- expect(stat.isFIFO() === false).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = fileIO.statSync(file.fd);
- expect(stat2.isFIFO() === false).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_stat_sync_is_fifo_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISFIFO_0100
- * @tc.name fileIO_stat_sync_is_fifo_001
- * @tc.desc Test the isFIFO() method of class Stat.
- * This interface does not require parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_is_fifo_001', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_is_fifo_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.statSync(fpath).isFile(-1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_stat_sync_is_fifo_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISFIFO_0200
- * @tc.name fileIO_stat_sync_is_fifo_002
- * @tc.desc Test the isFIFO() method of class Stat.
- * This interface does not require parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_is_fifo_002', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_is_fifo_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath);
-
- try {
- fileIO.statSync(file.fd).isFile(-1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_stat_sync_is_fifo_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISFILE_0000
- * @tc.name fileIO_stat_sync_is_file_000
- * @tc.desc Test the isFile() method of class Stat.
- * This interface shall treat a normal file as a normal file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_is_file_000', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_is_file_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.statSync(fpath);
- expect(stat.isFile() === true).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = fileIO.statSync(file.fd);
- expect(stat2.isFile() === true).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_stat_sync_is_file_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISFILE_0100
- * @tc.name fileIO_stat_sync_is_file_002
- * @tc.desc Test the isFile() method of class Stat.
- * This interface shall not treat a directory as a normal file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_is_file_001', 0, async function () {
- let dpath = await nextFileName('fileIO_stat_sync_is_file_001');
-
- try {
- fileIO.mkdirSync(dpath);
- let stat = fileIO.statSync(dpath);
- expect(stat.isFile() === false).assertTrue();
-
- let file = fileIO.openSync(dpath, fileIO.OpenMode.DIR);
- let stat2 = fileIO.statSync(file.fd);
- expect(stat2.isFile() === false).assertTrue();
- fileIO.closeSync(file);
- fileIO.rmdirSync(dpath);
- } catch (e) {
- console.log('fileIO_stat_sync_is_file_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISFILE_0200
- * @tc.name fileIO_stat_sync_is_file_002
- * @tc.desc Test the isFile() method of class Stat.
- * This interface does not require parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_is_file_002', 0, async function () {
- let dpath = await nextFileName('fileIO_stat_sync_is_file_002');
-
- try {
- fileIO.mkdirSync(dpath);
- fileIO.statSync(dpath).isFile(-1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.rmdirSync(dpath);
- console.log('fileIO_stat_sync_is_file_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISFILE_0300
- * @tc.name fileIO_stat_sync_is_file_003
- * @tc.desc Test the isFile() method of class Stat.
- * This interface does not require parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_is_file_003', 0, async function () {
- let dpath = await nextFileName('fileIO_stat_sync_is_file_003');
- fileIO.mkdirSync(dpath);
- let file = fileIO.openSync(dpath, fileIO.OpenMode.DIR);
-
- try {
- fileIO.statSync(file.fd).isFile(-1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.rmdirSync(dpath);
- console.log('fileIO_stat_sync_is_file_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISSOCKET_0000
- * @tc.name fileIO_stat_sync_is_socket_000
- * @tc.desc Test the isSocket() method of class Stat.
- * This interface shall not treat a file as a socket.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_is_socket_000', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_is_socket_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.statSync(fpath);
- expect(stat.isSocket() === false).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = fileIO.statSync(file.fd);
- expect(stat2.isSocket() === false).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_stat_sync_is_socket_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISSOCKET_0100
- * @tc.name fileIO_stat_sync_is_socket_001
- * @tc.desc Test the isSocket() method of class Stat.
- * This interface does not require parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_is_socket_001', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_is_socket_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.statSync(fpath).isSocket(-1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_stat_sync_is_socket_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISSOCKET_0200
- * @tc.name fileIO_stat_sync_is_socket_002
- * @tc.desc Test the isSocket() method of class Stat.
- * This interface does not require parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_is_socket_002', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_is_socket_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath);
-
- try {
- fileIO.statSync(file.fd).isSocket(-1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_stat_sync_is_socket_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISSYMBOLICLINK_0000
- * @tc.name fileIO_stat_sync_is_symbolic_link_000
- * @tc.desc Test the isSymbolicLink() method of class Stat.
- * This interface shall not treat a normal file as a symbolic link.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_is_symbolic_link_000', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_is_symbolic_link_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.statSync(fpath);
- expect(stat.isSymbolicLink() === false).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = fileIO.statSync(file.fd);
- expect(stat2.isSymbolicLink() === false).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_stat_sync_is_symbolic_link_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISSYMBOLICLINK_0100
- * @tc.name fileIO_stat_sync_is_symbolic_link_001
- * @tc.desc Test the isSymbolicLink() method of class Stat.
- * This interface does not require parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_is_symbolic_link_001', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_is_symbolic_link_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.statSync(fpath).isSymbolicLink(-1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_stat_sync_is_symbolic_link_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISSYMBOLICLINK_0200
- * @tc.name fileIO_stat_sync_is_symbolic_link_002
- * @tc.desc Test the isSymbolicLink() method of class Stat.
- * This interface does not require parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_sync_is_symbolic_link_002', 0, async function () {
- let fpath = await nextFileName('fileIO_stat_sync_is_symbolic_link_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath);
-
- try {
- fileIO.statSync(file.fd).isSymbolicLink(-1);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_stat_sync_is_symbolic_link_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_0000
- * @tc.name fileIO_stat_async_000
- * @tc.desc Test stat() interface. Promise.then().catch()
- * Enter the path or fd parameter to get the file stat.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_stat_async_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.stat(fpath).then((stat) => {
- expect(stat !== null).assertTrue();
- }).catch((err) => {
- console.log('fileIO_stat_async_000 error package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- });
-
- let file = fileIO.openSync(fpath);
- fileIO.stat(file.fd).then((stat2) => {
- expect(stat2 !== null).assertTrue();
- fileIO.closeSync(file);
- }).catch((err) => {
- console.log('fileIO_stat_async_000 error package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- });
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_stat_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_0100
- * @tc.name fileIO_stat_async_001
- * @tc.desc Test stat() interface. Promise.
- * Enter the path or fd parameter to get the file stat.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_stat_async_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.stat(fpath);
- expect(stat !== null).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = await fileIO.stat(file.fd);
- expect(stat2 !== null).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_stat_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_0200
- * @tc.name fileIO_stat_async_002
- * @tc.desc Test stat() interface. Callback.
- * Enter the path or fd parameter to get the file stat.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_002', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.stat(fpath, (err, stat) => {
- if(err) {
- console.log('fileIO_stat_async_002 error package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(stat !== null).assertTrue();
- });
-
- let file = fileIO.openSync(fpath);
- fileIO.stat(file.fd, (err, stat2) => {
- if(err) {
- console.log('fileIO_stat_async_002 error package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(stat2 !== null).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_stat_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_0300
- * @tc.name fileIO_stat_async_003
- * @tc.desc Test stat() interface. Promise.
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_003', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_003');
-
- try {
- await fileIO.stat(fpath)
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_stat_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_0400
- * @tc.name fileIO_stat_async_004
- * @tc.desc Test stat() interface. Callback.
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_004', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_004');
-
- try {
- fileIO.stat(fpath, (err) => {
- if (err) {
- console.log('fileIO_stat_async_004 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('fileIO_stat_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_0500
- * @tc.name fileIO_stat_async_005
- * @tc.desc Test stat() interface. Promise.
- * Invalid path or fd parameter.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_005', 0, async function (done) {
-
- try {
- await fileIO.stat(-1)
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_stat_async_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_0600
- * @tc.name fileIO_stat_async_006
- * @tc.desc Test stat() interface. Callback.
- * Invalid path or fd parameter.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_006', 0, async function (done) {
-
- try {
- fileIO.stat(-1, (err) => {
- expect(false).assertTrue();
- });
- } catch (e) {
- console.log('fileIO_stat_async_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_INO_0000
- * @tc.name fileIO_stat_async_ino_000
- * @tc.desc Test the ino member of class Stat. Promise.
- * Enter the path or fd parameter to get stat.ino of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_ino_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_ino_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.stat(fpath);
- expect(isBigInt(stat.ino)).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = await fileIO.stat(file.fd);
- expect(isBigInt(stat2.ino)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_stat_async_ino_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_INO_0100
- * @tc.name fileIO_stat_async_ino_001
- * @tc.desc Test the ino member of class Stat. Callback.
- * Enter the path or fd parameter to get stat.atime of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_ino_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_ino_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.stat(fpath, (err, stat) => {
- if(err) {
- console.log('fileIO_stat_async_ino_001 error package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isBigInt(stat.ino)).assertTrue();
- });
-
- let file = fileIO.openSync(fpath);
- fileIO.stat(file.fd, (err, stat2) => {
- if(err) {
- console.log('fileIO_stat_async_ino_001 error package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isBigInt(stat2.ino)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_stat_async_ino_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_MODE_0000
- * @tc.name fileIO_stat_async_mode_000
- * @tc.desc Test the mode member of class Stat. Promise.
- * Enter the path or fd parameter to get stat.mode of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_mode_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_mode_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.stat(fpath);
- expect(isIntNum(stat.mode)).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = await fileIO.stat(file.fd);
- expect(isIntNum(stat2.mode)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_stat_async_mode_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_MODE_0100
- * @tc.name fileIO_stat_async_mode_001
- * @tc.desc Test the mode member of class Stat. Callback.
- * Enter the path or fd parameter to get stat.mode of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_mode_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_mode_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.stat(fpath, (err, stat) => {
- if(err) {
- console.log('fileIO_stat_async_mode_001 error package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(stat.mode)).assertTrue();
- });
-
- let file = fileIO.openSync(fpath);
- fileIO.stat(file.fd, (err, stat2) => {
- if(err) {
- console.log('fileIO_stat_async_mode_001 error package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(stat2.mode)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_stat_async_mode_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_UID_0000
- * @tc.name fileIO_stat_async_uid_000
- * @tc.desc Test the uid member of class Stat. Promise.
- * Enter the path or fd parameter to get stat.uid of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_uid_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_uid_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.stat(fpath);
- expect(isIntNum(stat.uid)).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = await fileIO.stat(file.fd);
- expect(isIntNum(stat2.uid)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_stat_async_uid_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_UID_0100
- * @tc.name fileIO_stat_async_uid_001
- * @tc.desc Test the uid member of class Stat. Callback.
- * Enter the path or fd parameter to get stat.uid of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_uid_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_uid_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.stat(fpath, (err, stat) => {
- if(err) {
- console.log('fileIO_stat_async_uid_001 error package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(stat.uid)).assertTrue();
- });
-
- let file = fileIO.openSync(fpath);
- fileIO.stat(file.fd, (err, stat2) => {
- if(err) {
- console.log('fileIO_stat_async_uid_001 error package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(stat2.uid)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_stat_async_uid_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_GID_0000
- * @tc.name fileIO_stat_async_gid_000
- * @tc.desc Test the gid member of class Stat. Promise.
- * Enter the path or fd parameter to get stat.gid of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_gid_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_gid_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.stat(fpath);
- expect(isIntNum(stat.gid)).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = await fileIO.stat(file.fd);
- expect(isIntNum(stat2.gid)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_stat_async_gid_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_GID_0100
- * @tc.name fileIO_stat_async_gid_001
- * @tc.desc Test the gid member of class Stat. Callback.
- * Enter the path or fd parameter to get stat.gid of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_gid_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_gid_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.stat(fpath, (err, stat) => {
- if(err) {
- console.log('fileIO_stat_async_gid_001 error package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(stat.gid)).assertTrue();
- });
-
- let file = fileIO.openSync(fpath);
- fileIO.stat(file.fd, (err, stat2) => {
- if(err) {
- console.log('fileIO_stat_async_gid_001 error package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(stat2.gid)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_stat_async_gid_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_SIZE_0000
- * @tc.name fileIO_stat_async_size_000
- * @tc.desc Test the size member of class Stat. Promise.
- * Enter the path or fd parameter to get stat.size of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_size_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_size_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.stat(fpath);
- expect(isIntNum(stat.size)).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = await fileIO.stat(file.fd);
- expect(isIntNum(stat2.size)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_stat_async_size_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_SIZE_0100
- * @tc.name fileIO_stat_async_size_001
- * @tc.desc Test the size member of class Stat. Callback.
- * Enter the path or fd parameter to get stat.size of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_size_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_size_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.stat(fpath, (err, stat) => {
- if(err) {
- console.log('fileIO_stat_async_size_001 error package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(stat.size)).assertTrue();
- });
-
- let file = fileIO.openSync(fpath);
- fileIO.stat(file.fd, (err, stat2) => {
- if(err) {
- console.log('fileIO_stat_async_size_001 error package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(stat2.size)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_stat_async_size_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ATIME_0000
- * @tc.name fileIO_stat_async_atime_000
- * @tc.desc Test the atime member of class Stat. Promise.
- * Enter the path or fd parameter to get stat.atime of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_atime_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_atime_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.stat(fpath);
- expect(isIntNum(stat.atime)).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = await fileIO.stat(file.fd);
- expect(isIntNum(stat2.atime)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_stat_async_atime_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ATIME_0100
- * @tc.name fileIO_stat_async_atime_001
- * @tc.desc Test the atime member of class Stat. Callback.
- * Enter the path or fd parameter to get stat.atime of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_atime_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_atime_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.stat(fpath, (err, stat) => {
- if(err) {
- console.log('fileIO_stat_async_atime_001 error package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(stat.atime)).assertTrue();
- });
-
- let file = fileIO.openSync(fpath);
- fileIO.stat(file.fd, (err, stat2) => {
- if(err) {
- console.log('fileIO_stat_async_atime_001 error package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(stat2.atime)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_stat_async_atime_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_MTIME_0000
- * @tc.name fileIO_stat_async_mtime_000
- * @tc.desc Test the mtime member of class Stat. Promise.
- * Enter the path or fd parameter to get stat.mtime of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_mtime_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_mtime_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.stat(fpath);
- expect(isIntNum(stat.mtime)).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = await fileIO.stat(file.fd);
- expect(isIntNum(stat2.mtime)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_stat_async_mtime_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_MTIME_0100
- * @tc.name fileIO_stat_async_mtime_001
- * @tc.desc Test the mtime member of class Stat. Callback.
- * Enter the path or fd parameter to get stat.mtime of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_mtime_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_mtime_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.stat(fpath, (err, stat) => {
- if(err) {
- console.log('fileIO_stat_async_mtime_001 error package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(stat.mtime)).assertTrue();
- });
-
- let file = fileIO.openSync(fpath);
- fileIO.stat(file.fd, (err, stat2) => {
- if(err) {
- console.log('fileIO_stat_async_mtime_001 error package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(stat2.mtime)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_stat_async_mtime_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_CTIME_0000
- * @tc.name fileIO_stat_async_ctime_000
- * @tc.desc Test the ctime member of class Stat. Promise.
- * Enter the path or fd parameter to get stat.ctime of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_ctime_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_ctime_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.stat(fpath);
- expect(isIntNum(stat.ctime)).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = await fileIO.stat(file.fd);
- expect(isIntNum(stat2.ctime)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_stat_async_ctime_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_CTIME_0100
- * @tc.name fileIO_stat_async_ctime_001
- * @tc.desc Test the ctime member of class Stat. Callback.
- * Enter the path or fd parameter to get stat.ctime of the file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_ctime_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_ctime_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.stat(fpath, (err, stat) => {
- if(err) {
- console.log('fileIO_stat_async_ctime_001 error package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(stat.ctime)).assertTrue();
- });
-
- let file = fileIO.openSync(fpath);
- fileIO.stat(file.fd, (err, stat2) => {
- if(err) {
- console.log('fileIO_stat_async_ctime_001 error package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(isIntNum(stat2.ctime)).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_stat_async_ctime_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISBLOCKDEVICE_0000
- * @tc.name fileIO_stat_async_is_block_device_000
- * @tc.desc Test the isBlockDevice() method of class Stat. Promise.
- * This interface shall not treat a normal file as a block special device.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_is_block_device_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_is_block_device_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.stat(fpath);
- expect(stat.isBlockDevice() === false).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = await fileIO.stat(file.fd);
- expect(stat2.isBlockDevice() === false).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_stat_async_is_block_device_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISBLOCKDEVICE_0100
- * @tc.name fileIO_stat_async_is_block_device_001
- * @tc.desc Test the isBlockDevice() method of class Stat. Callback.
- * This interface shall not treat a normal file as a block special device.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_is_block_device_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_is_block_device_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.stat(fpath, (err, stat) => {
- if(err) {
- console.log('fileIO_stat_async_is_block_device_001 error package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(stat.isBlockDevice() === false).assertTrue();
- });
-
- let file = fileIO.openSync(fpath);
- fileIO.stat(file.fd, (err, stat2) => {
- if(err) {
- console.log('fileIO_stat_async_is_block_device_001 error package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(stat2.isBlockDevice() === false).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_stat_async_is_block_device_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISCHARACTERDEVICE_0000
- * @tc.name fileIO_stat_async_is_character_device_000
- * @tc.desc Test the isCharacterDevice() method of class Stat. Promise.
- * This interface shall not treat a normal file as a character special device.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_is_character_device_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_is_character_device_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.stat(fpath);
- expect(stat.isCharacterDevice() === false).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = await fileIO.stat(file.fd);
- expect(stat2.isCharacterDevice() === false).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_stat_async_is_character_device_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISCHARACTERDEVICE_0100
- * @tc.name fileIO_stat_async_is_character_device_001
- * @tc.desc Test the isCharacterDevice() method of class Stat. Callback.
- * This interface shall not treat a normal file as a character special device.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_is_character_device_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_is_character_device_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.stat(fpath, (err, stat) => {
- if(err) {
- console.log('fileIO_stat_async_is_character_device_001 error package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(stat.isCharacterDevice() === false).assertTrue();
- });
-
- let file = fileIO.openSync(fpath);
- fileIO.stat(file.fd, (err, stat2) => {
- if(err) {
- console.log('fileIO_stat_async_is_character_device_001 error package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(stat2.isCharacterDevice() === false).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_stat_async_is_character_device_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISDIRECTORY_0000
- * @tc.name fileIO_stat_async_is_directory_000
- * @tc.desc Test the isDirectory() method of class Stat. Promise.
- * This interface shall not treat a normal file as a directory.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_is_directory_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_is_directory_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.stat(fpath);
- expect(stat.isDirectory() === false).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = await fileIO.stat(file.fd);
- expect(stat2.isDirectory() === false).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_stat_async_is_directory_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISDIRECTORY_0100
- * @tc.name fileIO_stat_async_is_directory_001
- * @tc.desc Test the isDirectory() method of class Stat. Promise.
- * This interface shall not treat a directory as a directory.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_is_directory_001', 0, async function (done) {
- let dpath = await nextFileName('fileIO_stat_async_is_directory_001') + 'd';
-
- try {
- fileIO.mkdirSync(dpath);
- let stat = await fileIO.stat(dpath);
- expect(stat.isDirectory() === true).assertTrue();
-
- let file = fileIO.openSync(dpath, fileIO.OpenMode.DIR);
- let stat2 = await fileIO.stat(file.fd);
- expect(stat2.isDirectory() === true).assertTrue();
- fileIO.closeSync(file);
- fileIO.rmdirSync(dpath);
- done();
- } catch (e) {
- console.log('fileIO_stat_async_is_directory_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISDIRECTORY_0200
- * @tc.name fileIO_stat_async_is_directory_002
- * @tc.desc Test the isDirectory() method of class Stat. Callback.
- * This interface shall not treat a directory as a directory.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_is_directory_002', 0, async function (done) {
- let dpath = await nextFileName('fileIO_stat_async_is_directory_002') + 'd';
-
- try {
- fileIO.mkdirSync(dpath);
- fileIO.stat(dpath, (err, stat) => {
- if(err) {
- console.log('fileIO_stat_async_is_directory_002 error package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(stat.isDirectory() === true).assertTrue();
- });
-
- let file = fileIO.openSync(dpath, fileIO.OpenMode.DIR);
- fileIO.stat(file.fd, (err, stat2) => {
- if(err) {
- console.log('fileIO_stat_async_is_directory_002 error package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(stat2.isDirectory() === true).assertTrue();
- fileIO.closeSync(file);
- fileIO.rmdirSync(dpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_stat_async_is_directory_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISFIFO_0000
- * @tc.name fileIO_stat_async_is_fifo_000
- * @tc.desc Test the isFIFO() method of class Stat. Promise.
- * This interface shall not treat a normal file as a FIFO.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_is_fifo_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_is_fifo_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.stat(fpath);
- expect(stat.isFIFO() === false).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = await fileIO.stat(file.fd);
- expect(stat2.isFIFO() === false).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_stat_async_is_fifo_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISFIFO_0100
- * @tc.name fileIO_stat_async_is_fifo_001
- * @tc.desc Test the isFIFO() method of class Stat. Callback.
- * This interface shall not treat a normal file as a FIFO.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_is_fifo_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_is_fifo_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.stat(fpath, (err, stat) => {
- if(err) {
- console.log('fileIO_stat_async_is_fifo_001 error package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(stat.isFIFO() === false).assertTrue();
- });
-
- let file = fileIO.openSync(fpath);
- fileIO.stat(file.fd, (err, stat2) => {
- if(err) {
- console.log('fileIO_stat_async_is_fifo_001 error package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(stat2.isFIFO() === false).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_stat_async_is_fifo_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISFILE_0000
- * @tc.name fileIO_stat_async_is_file_000
- * @tc.desc Test the isFile() method of class Stat. Promise.
- * This interface shall treat a normal file as a normal file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_is_file_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_is_file_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.stat(fpath);
- expect(stat.isFile() === true).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = await fileIO.stat(file.fd);
- expect(stat2.isFile() === true).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_stat_async_is_file_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISFILE_0100
- * @tc.name fileIO_stat_async_is_file_001
- * @tc.desc Test the isFile() method of class Stat. Callback.
- * This interface shall treat a normal file as a normal file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_is_file_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_is_file_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.stat(fpath, (err, stat) => {
- if(err) {
- console.log('fileIO_stat_async_is_file_001 error package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(stat.isFile() === true).assertTrue();
- });
-
- let file = fileIO.openSync(fpath);
- fileIO.stat(file.fd, (err, stat2) => {
- if(err) {
- console.log('fileIO_stat_async_is_file_001 error package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(stat2.isFile() === true).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_stat_async_is_file_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISFILE_0200
- * @tc.name fileIO_stat_async_is_file_002
- * @tc.desc Test the isFile() method of class Stat. Promise.
- * This interface shall not treat a directory as a normal file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_is_file_002', 0, async function (done) {
- let dpath = await nextFileName('fileIO_stat_async_is_file_002');
-
- try {
- fileIO.mkdirSync(dpath);
- let stat = await fileIO.stat(dpath);
- expect(stat.isFile() === false).assertTrue();
-
- let file = fileIO.openSync(dpath, fileIO.OpenMode.DIR);
- let stat2 = await fileIO.stat(file.fd);
- expect(stat2.isFile() === false).assertTrue();
- fileIO.closeSync(file);
- fileIO.rmdirSync(dpath);
- done();
- } catch (e) {
- console.log('fileIO_stat_async_is_file_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISSOCKET_0000
- * @tc.name fileIO_stat_async_is_socket_000
- * @tc.desc Test the isSocket() method of class Stat. Promise.
- * This interface shall not treat a file as a socket.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_is_socket_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_is_socket_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.stat(fpath);
- expect(stat.isSocket() === false).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = await fileIO.stat(file.fd);
- expect(stat2.isSocket() === false).assertTrue();
- fileIO.closeSync(file);
- done();
- } catch (e) {
- console.log('fileIO_stat_async_is_socket_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISSOCKET_0100
- * @tc.name fileIO_stat_async_is_socket_001
- * @tc.desc Test the isSocket() method of class Stat. Callback.
- * This interface shall not treat a file as a socket.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_is_socket_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_is_socket_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.stat(fpath, (err, stat) => {
- if(err) {
- console.log('fileIO_stat_async_is_socket_001 error package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(stat.isSocket() === false).assertTrue();
- });
-
- let file = fileIO.openSync(fpath);
- fileIO.stat(file.fd, (err, stat2) => {
- if(err) {
- console.log('fileIO_stat_async_is_socket_001 error package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(stat2.isSocket() === false).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_stat_async_is_socket_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISSYMBOLICLINK_0000
- * @tc.name fileIO_stat_async_is_symbolic_link_000
- * @tc.desc Test the isSymbolicLink() method of class Stat. Promise.
- * This interface shall not treat a normal file as a symbolic link.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_is_symbolic_link_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_is_symbolic_link_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = await fileIO.stat(fpath);
- expect(stat.isSymbolicLink() === false).assertTrue();
-
- let file = fileIO.openSync(fpath);
- let stat2 = await fileIO.stat(file.fd);
- expect(stat2.isSymbolicLink() === false).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_stat_async_is_symbolic_link_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISSYMBOLICLINK_0100
- * @tc.name fileIO_stat_async_is_symbolic_link_001
- * @tc.desc Test the isSymbolicLink() method of class Stat. Callback.
- * This interface shall not treat a normal file as a symbolic link.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_stat_async_is_symbolic_link_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_stat_async_is_symbolic_link_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.stat(fpath, (err, stat) => {
- if(err) {
- console.log('fileIO_stat_async_is_symbolic_link_001 error package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(stat.isSymbolicLink() === false).assertTrue();
- });
-
- let file = fileIO.openSync(fpath);
- fileIO.stat(file.fd, (err, stat2) => {
- if(err) {
- console.log('fileIO_stat_async_is_symbolic_link_001 error package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(stat2.isSymbolicLink() === false).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_stat_async_is_symbolic_link_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_APPEND_FILE_SYNC_0000
- * @tc.name fileIO_stat_sync_append_file_sync_000
- * @tc.desc Test statSync() interface.
- * Modify the file, view the file status changes by path.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_append_file_sync_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_append_file_sync_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let stat = fileIO.statSync(fpath);
- expect(isIntNum(stat.size)).assertTrue();
-
- let file = fileIO.openSync(fpath, fileIO.OpenMode.APPEND | fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- expect(fileIO.writeSync(file.fd, FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- fileIO.closeSync(file);
-
- stat = fileIO.statSync(fpath);
- expect(stat.size == FILE_CONTENT.length * 2).assertTrue();
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_append_file_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_STAT_SYNC_APPEND_FILE_SYNC_0100
- * @tc.name fileIO_stat_sync_append_file_sync_001
- * @tc.desc Test statSync() interface.
- * Modify the file, view the file status changes by fd.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_append_file_sync_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_append_file_sync_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.APPEND | fileIO.OpenMode.READ_WRITE);
- let stat = fileIO.statSync(file.fd);
- expect(isIntNum(stat.size)).assertTrue();
- expect(isIntNum(file.fd)).assertTrue();
- expect(fileIO.writeSync(file.fd, FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
- fileIO.closeSync(file);
-
- let file2 = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- stat = fileIO.statSync(file2.fd);
- expect(stat.size == FILE_CONTENT.length * 2).assertTrue();
- fileIO.closeSync(file2);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_append_file_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-});
-}
+/*
+ * Copyright (C) 2022 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import {
+ fileIO, FILE_CONTENT, prepareFile, nextFileName, isIntNum, isBigInt,
+ describe, it, expect,
+ } from '../Common';
+
+export default function fileIOStat() {
+describe('fileIO_fs_stat', function () {
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_0000
+ * @tc.name fileIO_stat_sync_000
+ * @tc.desc Test statSync() interfaces.
+ * Enter the path or fd parameter to get the file stat.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_stat_sync_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.statSync(fpath);
+ expect(stat !== null).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = fileIO.statSync(file.fd);
+ expect(stat2 !== null).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_stat_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_0100
+ * @tc.name fileIO_stat_sync_001
+ * @tc.desc Test statSync() interfaces.
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_001', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_001');
+
+ try {
+ fileIO.statSync(fpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_stat_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_0200
+ * @tc.name fileIO_stat_sync_002
+ * @tc.desc Test statSync() interfaces. Missing parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_002', 0, async function () {
+
+ try {
+ fileIO.statSync();
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_stat_sync_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_INO_0000
+ * @tc.name fileIO_stat_sync_ino_000
+ * @tc.desc Test the ino member of class Stat.
+ * Enter the path or fd parameter to get stat.ino of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_ino_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_ino_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.statSync(fpath);
+ expect(isBigInt(stat.ino)).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = fileIO.statSync(file.fd);
+ expect(isBigInt(stat2.ino)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_stat_sync_ino_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_MODE_0000
+ * @tc.name fileIO_stat_sync_mode_000
+ * @tc.desc Test the mode member of class Stat.
+ * Enter the path or fd parameter to get stat.mode of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_mode_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_mode_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.statSync(fpath);
+ expect(isIntNum(stat.mode)).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = fileIO.statSync(file.fd);
+ expect(isIntNum(stat2.mode)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_stat_sync_mode_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_UID_0000
+ * @tc.name fileIO_stat_sync_uid_000
+ * @tc.desc Test the uid member of class Stat.
+ * Enter the path or fd parameter to get stat.uid of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_uid_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_uid_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.statSync(fpath);
+ expect(isIntNum(stat.uid)).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = fileIO.statSync(file.fd);
+ expect(isIntNum(stat2.uid)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_stat_sync_uid_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_GID_0000
+ * @tc.name fileIO_stat_sync_gid_000
+ * @tc.desc Test the gid member of class Stat.
+ * Enter the path or fd parameter to get stat.gid of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_gid_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_gid_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.statSync(fpath);
+ expect(isIntNum(stat.gid)).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = fileIO.statSync(file.fd);
+ expect(isIntNum(stat2.gid)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_stat_sync_gid_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_SIZE_0000
+ * @tc.name fileIO_stat_sync_size_000
+ * @tc.desc Test the size member of class Stat.
+ * Enter the path or fd parameter to get stat.size of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_size_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_size_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.statSync(fpath);
+ expect(isIntNum(stat.size)).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = fileIO.statSync(file.fd);
+ expect(isIntNum(stat2.size)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_stat_sync_size_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_ATIME_0000
+ * @tc.name fileIO_stat_sync_atime_000
+ * @tc.desc Test the atime member of class Stat.
+ * Enter the path or fd parameter to get stat.atime of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_atime_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_atime_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.statSync(fpath);
+ expect(isIntNum(stat.atime)).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = fileIO.statSync(file.fd);
+ expect(isIntNum(stat2.atime)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_stat_sync_atime_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_MTIME_0000
+ * @tc.name fileIO_stat_sync_mtime_000
+ * @tc.desc Test the mtime member of class Stat.
+ * Enter the path or fd parameter to get stat.mtime of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_mtime_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_mtime_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.statSync(fpath);
+ expect(isIntNum(stat.mtime)).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = fileIO.statSync(file.fd);
+ expect(isIntNum(stat2.mtime)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_stat_sync_mtime_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_CTIME_0000
+ * @tc.name fileIO_stat_sync_ctime_000
+ * @tc.desc Test the ctime member of class Stat.
+ * Enter the path or fd parameter to get stat.ctime of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_ctime_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_ctime_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.statSync(fpath);
+ expect(isIntNum(stat.ctime)).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = fileIO.statSync(file.fd);
+ expect(isIntNum(stat2.ctime)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_stat_sync_ctime_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISBLOCKDEVICE_0000
+ * @tc.name fileIO_stat_sync_is_block_device_000
+ * @tc.desc Test the isBlockDevice() method of class Stat.
+ * This interface shall not treat a normal file as a block special device.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_is_block_device_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_is_block_device_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.statSync(fpath);
+ expect(stat.isBlockDevice() === false).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = fileIO.statSync(file.fd);
+ expect(stat2.isBlockDevice() === false).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_stat_sync_is_block_device_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISBLOCKDEVICE_0100
+ * @tc.name fileIO_stat_sync_is_block_device_001
+ * @tc.desc Test the isBlockDevice() method of class Stat.
+ * This interface does not require parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_is_block_device_001', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_is_block_device_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.statSync(fpath).isBlockDevice(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_stat_sync_is_block_device_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISBLOCKDEVICE_0200
+ * @tc.name fileIO_stat_sync_is_block_device_002
+ * @tc.desc Test the isBlockDevice() method of class Stat.
+ * This interface does not require parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_is_block_device_002', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_is_block_device_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath);
+
+ try {
+ fileIO.statSync(file.fd).isBlockDevice(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_stat_sync_is_block_device_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISCHARACTER_DEVICE_0000
+ * @tc.name fileIO_stat_sync_is_character_device_000
+ * @tc.desc Test the isCharacterDevice() method of class Stat.
+ * This interface shall not treat a normal file as a character special device.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_is_character_device_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_is_character_device_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.statSync(fpath);
+ expect(stat.isCharacterDevice() === false).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = fileIO.statSync(file.fd);
+ expect(stat2.isCharacterDevice() === false).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_stat_sync_is_character_device_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISCHARACTER_DEVICE_0100
+ * @tc.name fileIO_stat_sync_is_character_device_001
+ * @tc.desc Test the isCharacterDevice() method of class Stat.
+ * This interface does not require parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_is_character_device_001', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_is_character_device_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.statSync(fpath).isCharacterDevice(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_stat_sync_is_character_device_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISCHARACTER_DEVICE_0200
+ * @tc.name fileIO_stat_sync_is_character_device_002
+ * @tc.desc Test the isCharacterDevice() method of class Stat.
+ * This interface does not require parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_is_character_device_002', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_is_character_device_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath);
+
+ try {
+ fileIO.statSync(file.fd).isCharacterDevice(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_stat_sync_is_character_device_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISDIRECTORY_0000
+ * @tc.name fileIO_stat_sync_is_directory_000
+ * @tc.desc Test the isDirectory() method of class Stat.
+ * This interface shall not treat a normal file as a directory.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_is_directory_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_is_directory_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.statSync(fpath);
+ expect(stat.isDirectory() === false).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = fileIO.statSync(file.fd);
+ expect(stat2.isDirectory() === false).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_stat_sync_is_directory_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISDIRECTORY_0100
+ * @tc.name fileIO_stat_sync_is_directory_001
+ * @tc.desc Test the isDirectory() method of class Stat.
+ * This interface shall treat a directory as a directory.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_is_directory_001', 0, async function () {
+ let dpath = await nextFileName('fileIO_stat_sync_is_directory_001');
+
+ try {
+ fileIO.mkdirSync(dpath);
+ let stat = fileIO.statSync(dpath);
+ expect(stat.isDirectory() === true).assertTrue();
+
+ let file = fileIO.openSync(dpath, fileIO.OpenMode.DIR);
+ let stat2 = fileIO.statSync(file.fd);
+ expect(stat2.isDirectory() === true).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.rmdirSync(dpath);
+ } catch (e) {
+ console.log('fileIO_stat_sync_is_directory_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISDIRECTORY_0200
+ * @tc.name fileIO_stat_sync_is_directory_002
+ * @tc.desc Test the isDirectory() method of class Stat.
+ * This interface does not require parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_is_directory_002', 0, async function () {
+ let dpath = await nextFileName('fileIO_stat_sync_is_directory_002') + 'd';
+
+ try {
+ fileIO.mkdirSync(dpath);
+ fileIO.statSync(dpath).isDirectory(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.rmdirSync(dpath);
+ console.log('fileIO_stat_sync_is_directory_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISDIRECTORY_0300
+ * @tc.name fileIO_stat_sync_is_directory_003
+ * @tc.desc Test the isDirectory() method of class Stat.
+ * This interface does not require parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_is_directory_003', 0, async function () {
+ let dpath = await nextFileName('fileIO_stat_sync_is_directory_003') + 'd';
+ fileIO.mkdirSync(dpath);
+ let file = fileIO.openSync(dpath, fileIO.OpenMode.DIR);
+
+ try {
+ fileIO.statSync(file.fd).isDirectory(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.rmdirSync(dpath);
+ console.log('fileIO_stat_sync_is_directory_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISFIFO_0000
+ * @tc.name fileIO_stat_sync_is_fifo_000
+ * @tc.desc Test the isFIFO() method of class Stat.
+ * This interface shall not treat a normal file as a FIFO.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_is_fifo_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_is_fifo_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.statSync(fpath);
+ expect(stat.isFIFO() === false).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = fileIO.statSync(file.fd);
+ expect(stat2.isFIFO() === false).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_stat_sync_is_fifo_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISFIFO_0100
+ * @tc.name fileIO_stat_sync_is_fifo_001
+ * @tc.desc Test the isFIFO() method of class Stat.
+ * This interface does not require parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_is_fifo_001', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_is_fifo_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.statSync(fpath).isFile(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_stat_sync_is_fifo_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISFIFO_0200
+ * @tc.name fileIO_stat_sync_is_fifo_002
+ * @tc.desc Test the isFIFO() method of class Stat.
+ * This interface does not require parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_is_fifo_002', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_is_fifo_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath);
+
+ try {
+ fileIO.statSync(file.fd).isFile(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_stat_sync_is_fifo_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISFILE_0000
+ * @tc.name fileIO_stat_sync_is_file_000
+ * @tc.desc Test the isFile() method of class Stat.
+ * This interface shall treat a normal file as a normal file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_is_file_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_is_file_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.statSync(fpath);
+ expect(stat.isFile() === true).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = fileIO.statSync(file.fd);
+ expect(stat2.isFile() === true).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_stat_sync_is_file_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISFILE_0100
+ * @tc.name fileIO_stat_sync_is_file_002
+ * @tc.desc Test the isFile() method of class Stat.
+ * This interface shall not treat a directory as a normal file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_is_file_001', 0, async function () {
+ let dpath = await nextFileName('fileIO_stat_sync_is_file_001');
+
+ try {
+ fileIO.mkdirSync(dpath);
+ let stat = fileIO.statSync(dpath);
+ expect(stat.isFile() === false).assertTrue();
+
+ let file = fileIO.openSync(dpath, fileIO.OpenMode.DIR);
+ let stat2 = fileIO.statSync(file.fd);
+ expect(stat2.isFile() === false).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.rmdirSync(dpath);
+ } catch (e) {
+ console.log('fileIO_stat_sync_is_file_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISFILE_0200
+ * @tc.name fileIO_stat_sync_is_file_002
+ * @tc.desc Test the isFile() method of class Stat.
+ * This interface does not require parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_is_file_002', 0, async function () {
+ let dpath = await nextFileName('fileIO_stat_sync_is_file_002');
+
+ try {
+ fileIO.mkdirSync(dpath);
+ fileIO.statSync(dpath).isFile(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.rmdirSync(dpath);
+ console.log('fileIO_stat_sync_is_file_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISFILE_0300
+ * @tc.name fileIO_stat_sync_is_file_003
+ * @tc.desc Test the isFile() method of class Stat.
+ * This interface does not require parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_is_file_003', 0, async function () {
+ let dpath = await nextFileName('fileIO_stat_sync_is_file_003');
+ fileIO.mkdirSync(dpath);
+ let file = fileIO.openSync(dpath, fileIO.OpenMode.DIR);
+
+ try {
+ fileIO.statSync(file.fd).isFile(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.rmdirSync(dpath);
+ console.log('fileIO_stat_sync_is_file_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISSOCKET_0000
+ * @tc.name fileIO_stat_sync_is_socket_000
+ * @tc.desc Test the isSocket() method of class Stat.
+ * This interface shall not treat a file as a socket.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_is_socket_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_is_socket_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.statSync(fpath);
+ expect(stat.isSocket() === false).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = fileIO.statSync(file.fd);
+ expect(stat2.isSocket() === false).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_stat_sync_is_socket_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISSOCKET_0100
+ * @tc.name fileIO_stat_sync_is_socket_001
+ * @tc.desc Test the isSocket() method of class Stat.
+ * This interface does not require parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_is_socket_001', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_is_socket_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.statSync(fpath).isSocket(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_stat_sync_is_socket_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISSOCKET_0200
+ * @tc.name fileIO_stat_sync_is_socket_002
+ * @tc.desc Test the isSocket() method of class Stat.
+ * This interface does not require parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_is_socket_002', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_is_socket_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath);
+
+ try {
+ fileIO.statSync(file.fd).isSocket(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_stat_sync_is_socket_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISSYMBOLICLINK_0000
+ * @tc.name fileIO_stat_sync_is_symbolic_link_000
+ * @tc.desc Test the isSymbolicLink() method of class Stat.
+ * This interface shall not treat a normal file as a symbolic link.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_is_symbolic_link_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_is_symbolic_link_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.statSync(fpath);
+ expect(stat.isSymbolicLink() === false).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = fileIO.statSync(file.fd);
+ expect(stat2.isSymbolicLink() === false).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_stat_sync_is_symbolic_link_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISSYMBOLICLINK_0100
+ * @tc.name fileIO_stat_sync_is_symbolic_link_001
+ * @tc.desc Test the isSymbolicLink() method of class Stat.
+ * This interface does not require parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_is_symbolic_link_001', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_is_symbolic_link_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.statSync(fpath).isSymbolicLink(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_stat_sync_is_symbolic_link_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_ISSYMBOLICLINK_0200
+ * @tc.name fileIO_stat_sync_is_symbolic_link_002
+ * @tc.desc Test the isSymbolicLink() method of class Stat.
+ * This interface does not require parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_sync_is_symbolic_link_002', 0, async function () {
+ let fpath = await nextFileName('fileIO_stat_sync_is_symbolic_link_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath);
+
+ try {
+ fileIO.statSync(file.fd).isSymbolicLink(-1);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_stat_sync_is_symbolic_link_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_0000
+ * @tc.name fileIO_stat_async_000
+ * @tc.desc Test stat() interface. Promise.then().catch()
+ * Enter the path or fd parameter to get the file stat.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_stat_async_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.stat(fpath).then((stat) => {
+ expect(stat !== null).assertTrue();
+ }).catch((err) => {
+ console.log('fileIO_stat_async_000 error package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ });
+
+ let file = fileIO.openSync(fpath);
+ fileIO.stat(file.fd).then((stat2) => {
+ expect(stat2 !== null).assertTrue();
+ fileIO.closeSync(file);
+ }).catch((err) => {
+ console.log('fileIO_stat_async_000 error package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ });
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_stat_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_0100
+ * @tc.name fileIO_stat_async_001
+ * @tc.desc Test stat() interface. Promise.
+ * Enter the path or fd parameter to get the file stat.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_stat_async_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.stat(fpath);
+ expect(stat !== null).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = await fileIO.stat(file.fd);
+ expect(stat2 !== null).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_stat_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_0200
+ * @tc.name fileIO_stat_async_002
+ * @tc.desc Test stat() interface. Callback.
+ * Enter the path or fd parameter to get the file stat.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_002', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.stat(fpath, (err, stat) => {
+ if(err) {
+ console.log('fileIO_stat_async_002 error package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(stat !== null).assertTrue();
+ });
+
+ let file = fileIO.openSync(fpath);
+ fileIO.stat(file.fd, (err, stat2) => {
+ if(err) {
+ console.log('fileIO_stat_async_002 error package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(stat2 !== null).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_stat_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_0300
+ * @tc.name fileIO_stat_async_003
+ * @tc.desc Test stat() interface. Promise.
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_003', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_003');
+
+ try {
+ await fileIO.stat(fpath)
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_stat_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_0400
+ * @tc.name fileIO_stat_async_004
+ * @tc.desc Test stat() interface. Callback.
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_004', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_004');
+
+ try {
+ fileIO.stat(fpath, (err) => {
+ if (err) {
+ console.log('fileIO_stat_async_004 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('fileIO_stat_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_0500
+ * @tc.name fileIO_stat_async_005
+ * @tc.desc Test stat() interface. Promise.
+ * Invalid path or fd parameter.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_005', 0, async function (done) {
+
+ try {
+ await fileIO.stat(-1)
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_stat_async_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_0600
+ * @tc.name fileIO_stat_async_006
+ * @tc.desc Test stat() interface. Callback.
+ * Invalid path or fd parameter.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_006', 0, async function (done) {
+
+ try {
+ fileIO.stat(-1, (err) => {
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ console.log('fileIO_stat_async_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_INO_0000
+ * @tc.name fileIO_stat_async_ino_000
+ * @tc.desc Test the ino member of class Stat. Promise.
+ * Enter the path or fd parameter to get stat.ino of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_ino_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_ino_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.stat(fpath);
+ expect(isBigInt(stat.ino)).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = await fileIO.stat(file.fd);
+ expect(isBigInt(stat2.ino)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_stat_async_ino_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_INO_0100
+ * @tc.name fileIO_stat_async_ino_001
+ * @tc.desc Test the ino member of class Stat. Callback.
+ * Enter the path or fd parameter to get stat.atime of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_ino_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_ino_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.stat(fpath, (err, stat) => {
+ if(err) {
+ console.log('fileIO_stat_async_ino_001 error package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isBigInt(stat.ino)).assertTrue();
+ });
+
+ let file = fileIO.openSync(fpath);
+ fileIO.stat(file.fd, (err, stat2) => {
+ if(err) {
+ console.log('fileIO_stat_async_ino_001 error package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isBigInt(stat2.ino)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_stat_async_ino_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_MODE_0000
+ * @tc.name fileIO_stat_async_mode_000
+ * @tc.desc Test the mode member of class Stat. Promise.
+ * Enter the path or fd parameter to get stat.mode of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_mode_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_mode_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.stat(fpath);
+ expect(isIntNum(stat.mode)).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = await fileIO.stat(file.fd);
+ expect(isIntNum(stat2.mode)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_stat_async_mode_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_MODE_0100
+ * @tc.name fileIO_stat_async_mode_001
+ * @tc.desc Test the mode member of class Stat. Callback.
+ * Enter the path or fd parameter to get stat.mode of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_mode_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_mode_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.stat(fpath, (err, stat) => {
+ if(err) {
+ console.log('fileIO_stat_async_mode_001 error package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(stat.mode)).assertTrue();
+ });
+
+ let file = fileIO.openSync(fpath);
+ fileIO.stat(file.fd, (err, stat2) => {
+ if(err) {
+ console.log('fileIO_stat_async_mode_001 error package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(stat2.mode)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_stat_async_mode_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_UID_0000
+ * @tc.name fileIO_stat_async_uid_000
+ * @tc.desc Test the uid member of class Stat. Promise.
+ * Enter the path or fd parameter to get stat.uid of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_uid_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_uid_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.stat(fpath);
+ expect(isIntNum(stat.uid)).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = await fileIO.stat(file.fd);
+ expect(isIntNum(stat2.uid)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_stat_async_uid_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_UID_0100
+ * @tc.name fileIO_stat_async_uid_001
+ * @tc.desc Test the uid member of class Stat. Callback.
+ * Enter the path or fd parameter to get stat.uid of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_uid_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_uid_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.stat(fpath, (err, stat) => {
+ if(err) {
+ console.log('fileIO_stat_async_uid_001 error package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(stat.uid)).assertTrue();
+ });
+
+ let file = fileIO.openSync(fpath);
+ fileIO.stat(file.fd, (err, stat2) => {
+ if(err) {
+ console.log('fileIO_stat_async_uid_001 error package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(stat2.uid)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_stat_async_uid_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_GID_0000
+ * @tc.name fileIO_stat_async_gid_000
+ * @tc.desc Test the gid member of class Stat. Promise.
+ * Enter the path or fd parameter to get stat.gid of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_gid_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_gid_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.stat(fpath);
+ expect(isIntNum(stat.gid)).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = await fileIO.stat(file.fd);
+ expect(isIntNum(stat2.gid)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_stat_async_gid_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_GID_0100
+ * @tc.name fileIO_stat_async_gid_001
+ * @tc.desc Test the gid member of class Stat. Callback.
+ * Enter the path or fd parameter to get stat.gid of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_gid_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_gid_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.stat(fpath, (err, stat) => {
+ if(err) {
+ console.log('fileIO_stat_async_gid_001 error package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(stat.gid)).assertTrue();
+ });
+
+ let file = fileIO.openSync(fpath);
+ fileIO.stat(file.fd, (err, stat2) => {
+ if(err) {
+ console.log('fileIO_stat_async_gid_001 error package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(stat2.gid)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_stat_async_gid_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_SIZE_0000
+ * @tc.name fileIO_stat_async_size_000
+ * @tc.desc Test the size member of class Stat. Promise.
+ * Enter the path or fd parameter to get stat.size of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_size_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_size_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.stat(fpath);
+ expect(isIntNum(stat.size)).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = await fileIO.stat(file.fd);
+ expect(isIntNum(stat2.size)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_stat_async_size_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_SIZE_0100
+ * @tc.name fileIO_stat_async_size_001
+ * @tc.desc Test the size member of class Stat. Callback.
+ * Enter the path or fd parameter to get stat.size of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_size_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_size_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.stat(fpath, (err, stat) => {
+ if(err) {
+ console.log('fileIO_stat_async_size_001 error package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(stat.size)).assertTrue();
+ });
+
+ let file = fileIO.openSync(fpath);
+ fileIO.stat(file.fd, (err, stat2) => {
+ if(err) {
+ console.log('fileIO_stat_async_size_001 error package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(stat2.size)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_stat_async_size_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ATIME_0000
+ * @tc.name fileIO_stat_async_atime_000
+ * @tc.desc Test the atime member of class Stat. Promise.
+ * Enter the path or fd parameter to get stat.atime of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_atime_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_atime_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.stat(fpath);
+ expect(isIntNum(stat.atime)).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = await fileIO.stat(file.fd);
+ expect(isIntNum(stat2.atime)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_stat_async_atime_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ATIME_0100
+ * @tc.name fileIO_stat_async_atime_001
+ * @tc.desc Test the atime member of class Stat. Callback.
+ * Enter the path or fd parameter to get stat.atime of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_atime_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_atime_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.stat(fpath, (err, stat) => {
+ if(err) {
+ console.log('fileIO_stat_async_atime_001 error package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(stat.atime)).assertTrue();
+ });
+
+ let file = fileIO.openSync(fpath);
+ fileIO.stat(file.fd, (err, stat2) => {
+ if(err) {
+ console.log('fileIO_stat_async_atime_001 error package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(stat2.atime)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_stat_async_atime_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_MTIME_0000
+ * @tc.name fileIO_stat_async_mtime_000
+ * @tc.desc Test the mtime member of class Stat. Promise.
+ * Enter the path or fd parameter to get stat.mtime of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_mtime_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_mtime_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.stat(fpath);
+ expect(isIntNum(stat.mtime)).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = await fileIO.stat(file.fd);
+ expect(isIntNum(stat2.mtime)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_stat_async_mtime_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_MTIME_0100
+ * @tc.name fileIO_stat_async_mtime_001
+ * @tc.desc Test the mtime member of class Stat. Callback.
+ * Enter the path or fd parameter to get stat.mtime of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_mtime_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_mtime_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.stat(fpath, (err, stat) => {
+ if(err) {
+ console.log('fileIO_stat_async_mtime_001 error package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(stat.mtime)).assertTrue();
+ });
+
+ let file = fileIO.openSync(fpath);
+ fileIO.stat(file.fd, (err, stat2) => {
+ if(err) {
+ console.log('fileIO_stat_async_mtime_001 error package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(stat2.mtime)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_stat_async_mtime_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_CTIME_0000
+ * @tc.name fileIO_stat_async_ctime_000
+ * @tc.desc Test the ctime member of class Stat. Promise.
+ * Enter the path or fd parameter to get stat.ctime of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_ctime_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_ctime_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.stat(fpath);
+ expect(isIntNum(stat.ctime)).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = await fileIO.stat(file.fd);
+ expect(isIntNum(stat2.ctime)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_stat_async_ctime_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_CTIME_0100
+ * @tc.name fileIO_stat_async_ctime_001
+ * @tc.desc Test the ctime member of class Stat. Callback.
+ * Enter the path or fd parameter to get stat.ctime of the file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_ctime_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_ctime_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.stat(fpath, (err, stat) => {
+ if(err) {
+ console.log('fileIO_stat_async_ctime_001 error package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(stat.ctime)).assertTrue();
+ });
+
+ let file = fileIO.openSync(fpath);
+ fileIO.stat(file.fd, (err, stat2) => {
+ if(err) {
+ console.log('fileIO_stat_async_ctime_001 error package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(isIntNum(stat2.ctime)).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_stat_async_ctime_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISBLOCKDEVICE_0000
+ * @tc.name fileIO_stat_async_is_block_device_000
+ * @tc.desc Test the isBlockDevice() method of class Stat. Promise.
+ * This interface shall not treat a normal file as a block special device.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_is_block_device_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_is_block_device_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.stat(fpath);
+ expect(stat.isBlockDevice() === false).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = await fileIO.stat(file.fd);
+ expect(stat2.isBlockDevice() === false).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_stat_async_is_block_device_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISBLOCKDEVICE_0100
+ * @tc.name fileIO_stat_async_is_block_device_001
+ * @tc.desc Test the isBlockDevice() method of class Stat. Callback.
+ * This interface shall not treat a normal file as a block special device.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_is_block_device_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_is_block_device_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.stat(fpath, (err, stat) => {
+ if(err) {
+ console.log('fileIO_stat_async_is_block_device_001 error package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(stat.isBlockDevice() === false).assertTrue();
+ });
+
+ let file = fileIO.openSync(fpath);
+ fileIO.stat(file.fd, (err, stat2) => {
+ if(err) {
+ console.log('fileIO_stat_async_is_block_device_001 error package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(stat2.isBlockDevice() === false).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_stat_async_is_block_device_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISCHARACTERDEVICE_0000
+ * @tc.name fileIO_stat_async_is_character_device_000
+ * @tc.desc Test the isCharacterDevice() method of class Stat. Promise.
+ * This interface shall not treat a normal file as a character special device.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_is_character_device_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_is_character_device_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.stat(fpath);
+ expect(stat.isCharacterDevice() === false).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = await fileIO.stat(file.fd);
+ expect(stat2.isCharacterDevice() === false).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_stat_async_is_character_device_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISCHARACTERDEVICE_0100
+ * @tc.name fileIO_stat_async_is_character_device_001
+ * @tc.desc Test the isCharacterDevice() method of class Stat. Callback.
+ * This interface shall not treat a normal file as a character special device.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_is_character_device_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_is_character_device_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.stat(fpath, (err, stat) => {
+ if(err) {
+ console.log('fileIO_stat_async_is_character_device_001 error package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(stat.isCharacterDevice() === false).assertTrue();
+ });
+
+ let file = fileIO.openSync(fpath);
+ fileIO.stat(file.fd, (err, stat2) => {
+ if(err) {
+ console.log('fileIO_stat_async_is_character_device_001 error package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(stat2.isCharacterDevice() === false).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_stat_async_is_character_device_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISDIRECTORY_0000
+ * @tc.name fileIO_stat_async_is_directory_000
+ * @tc.desc Test the isDirectory() method of class Stat. Promise.
+ * This interface shall not treat a normal file as a directory.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_is_directory_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_is_directory_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.stat(fpath);
+ expect(stat.isDirectory() === false).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = await fileIO.stat(file.fd);
+ expect(stat2.isDirectory() === false).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_stat_async_is_directory_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISDIRECTORY_0100
+ * @tc.name fileIO_stat_async_is_directory_001
+ * @tc.desc Test the isDirectory() method of class Stat. Promise.
+ * This interface shall not treat a directory as a directory.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_is_directory_001', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_stat_async_is_directory_001') + 'd';
+
+ try {
+ fileIO.mkdirSync(dpath);
+ let stat = await fileIO.stat(dpath);
+ expect(stat.isDirectory() === true).assertTrue();
+
+ let file = fileIO.openSync(dpath, fileIO.OpenMode.DIR);
+ let stat2 = await fileIO.stat(file.fd);
+ expect(stat2.isDirectory() === true).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.rmdirSync(dpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_stat_async_is_directory_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISDIRECTORY_0200
+ * @tc.name fileIO_stat_async_is_directory_002
+ * @tc.desc Test the isDirectory() method of class Stat. Callback.
+ * This interface shall not treat a directory as a directory.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_is_directory_002', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_stat_async_is_directory_002') + 'd';
+
+ try {
+ fileIO.mkdirSync(dpath);
+ fileIO.stat(dpath, (err, stat) => {
+ if(err) {
+ console.log('fileIO_stat_async_is_directory_002 error package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(stat.isDirectory() === true).assertTrue();
+ });
+
+ let file = fileIO.openSync(dpath, fileIO.OpenMode.DIR);
+ fileIO.stat(file.fd, (err, stat2) => {
+ if(err) {
+ console.log('fileIO_stat_async_is_directory_002 error package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(stat2.isDirectory() === true).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.rmdirSync(dpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_stat_async_is_directory_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISFIFO_0000
+ * @tc.name fileIO_stat_async_is_fifo_000
+ * @tc.desc Test the isFIFO() method of class Stat. Promise.
+ * This interface shall not treat a normal file as a FIFO.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_is_fifo_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_is_fifo_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.stat(fpath);
+ expect(stat.isFIFO() === false).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = await fileIO.stat(file.fd);
+ expect(stat2.isFIFO() === false).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_stat_async_is_fifo_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISFIFO_0100
+ * @tc.name fileIO_stat_async_is_fifo_001
+ * @tc.desc Test the isFIFO() method of class Stat. Callback.
+ * This interface shall not treat a normal file as a FIFO.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_is_fifo_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_is_fifo_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.stat(fpath, (err, stat) => {
+ if(err) {
+ console.log('fileIO_stat_async_is_fifo_001 error package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(stat.isFIFO() === false).assertTrue();
+ });
+
+ let file = fileIO.openSync(fpath);
+ fileIO.stat(file.fd, (err, stat2) => {
+ if(err) {
+ console.log('fileIO_stat_async_is_fifo_001 error package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(stat2.isFIFO() === false).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_stat_async_is_fifo_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISFILE_0000
+ * @tc.name fileIO_stat_async_is_file_000
+ * @tc.desc Test the isFile() method of class Stat. Promise.
+ * This interface shall treat a normal file as a normal file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_is_file_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_is_file_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.stat(fpath);
+ expect(stat.isFile() === true).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = await fileIO.stat(file.fd);
+ expect(stat2.isFile() === true).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_stat_async_is_file_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISFILE_0100
+ * @tc.name fileIO_stat_async_is_file_001
+ * @tc.desc Test the isFile() method of class Stat. Callback.
+ * This interface shall treat a normal file as a normal file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_is_file_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_is_file_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.stat(fpath, (err, stat) => {
+ if(err) {
+ console.log('fileIO_stat_async_is_file_001 error package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(stat.isFile() === true).assertTrue();
+ });
+
+ let file = fileIO.openSync(fpath);
+ fileIO.stat(file.fd, (err, stat2) => {
+ if(err) {
+ console.log('fileIO_stat_async_is_file_001 error package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(stat2.isFile() === true).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_stat_async_is_file_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISFILE_0200
+ * @tc.name fileIO_stat_async_is_file_002
+ * @tc.desc Test the isFile() method of class Stat. Promise.
+ * This interface shall not treat a directory as a normal file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_is_file_002', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_stat_async_is_file_002');
+
+ try {
+ fileIO.mkdirSync(dpath);
+ let stat = await fileIO.stat(dpath);
+ expect(stat.isFile() === false).assertTrue();
+
+ let file = fileIO.openSync(dpath, fileIO.OpenMode.DIR);
+ let stat2 = await fileIO.stat(file.fd);
+ expect(stat2.isFile() === false).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.rmdirSync(dpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_stat_async_is_file_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISSOCKET_0000
+ * @tc.name fileIO_stat_async_is_socket_000
+ * @tc.desc Test the isSocket() method of class Stat. Promise.
+ * This interface shall not treat a file as a socket.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_is_socket_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_is_socket_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.stat(fpath);
+ expect(stat.isSocket() === false).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = await fileIO.stat(file.fd);
+ expect(stat2.isSocket() === false).assertTrue();
+ fileIO.closeSync(file);
+ done();
+ } catch (e) {
+ console.log('fileIO_stat_async_is_socket_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISSOCKET_0100
+ * @tc.name fileIO_stat_async_is_socket_001
+ * @tc.desc Test the isSocket() method of class Stat. Callback.
+ * This interface shall not treat a file as a socket.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_is_socket_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_is_socket_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.stat(fpath, (err, stat) => {
+ if(err) {
+ console.log('fileIO_stat_async_is_socket_001 error package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(stat.isSocket() === false).assertTrue();
+ });
+
+ let file = fileIO.openSync(fpath);
+ fileIO.stat(file.fd, (err, stat2) => {
+ if(err) {
+ console.log('fileIO_stat_async_is_socket_001 error package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(stat2.isSocket() === false).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_stat_async_is_socket_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISSYMBOLICLINK_0000
+ * @tc.name fileIO_stat_async_is_symbolic_link_000
+ * @tc.desc Test the isSymbolicLink() method of class Stat. Promise.
+ * This interface shall not treat a normal file as a symbolic link.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_is_symbolic_link_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_is_symbolic_link_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = await fileIO.stat(fpath);
+ expect(stat.isSymbolicLink() === false).assertTrue();
+
+ let file = fileIO.openSync(fpath);
+ let stat2 = await fileIO.stat(file.fd);
+ expect(stat2.isSymbolicLink() === false).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_stat_async_is_symbolic_link_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_ASYNC_ISSYMBOLICLINK_0100
+ * @tc.name fileIO_stat_async_is_symbolic_link_001
+ * @tc.desc Test the isSymbolicLink() method of class Stat. Callback.
+ * This interface shall not treat a normal file as a symbolic link.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_stat_async_is_symbolic_link_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_stat_async_is_symbolic_link_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.stat(fpath, (err, stat) => {
+ if(err) {
+ console.log('fileIO_stat_async_is_symbolic_link_001 error package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(stat.isSymbolicLink() === false).assertTrue();
+ });
+
+ let file = fileIO.openSync(fpath);
+ fileIO.stat(file.fd, (err, stat2) => {
+ if(err) {
+ console.log('fileIO_stat_async_is_symbolic_link_001 error package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(stat2.isSymbolicLink() === false).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_stat_async_is_symbolic_link_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_APPEND_FILE_SYNC_0000
+ * @tc.name fileIO_stat_sync_append_file_sync_000
+ * @tc.desc Test statSync() interface.
+ * Modify the file, view the file status changes by path.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_append_file_sync_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_append_file_sync_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let stat = fileIO.statSync(fpath);
+ expect(isIntNum(stat.size)).assertTrue();
+
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.APPEND | fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ expect(fileIO.writeSync(file.fd, FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ fileIO.closeSync(file);
+
+ stat = fileIO.statSync(fpath);
+ expect(stat.size == FILE_CONTENT.length * 2).assertTrue();
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_append_file_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_STAT_SYNC_APPEND_FILE_SYNC_0100
+ * @tc.name fileIO_stat_sync_append_file_sync_001
+ * @tc.desc Test statSync() interface.
+ * Modify the file, view the file status changes by fd.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_append_file_sync_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_append_file_sync_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.APPEND | fileIO.OpenMode.READ_WRITE);
+ let stat = fileIO.statSync(file.fd);
+ expect(isIntNum(stat.size)).assertTrue();
+ expect(isIntNum(file.fd)).assertTrue();
+ expect(fileIO.writeSync(file.fd, FILE_CONTENT) == FILE_CONTENT.length).assertTrue();
+ fileIO.closeSync(file);
+
+ let file2 = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ stat = fileIO.statSync(file2.fd);
+ expect(stat.size == FILE_CONTENT.length * 2).assertTrue();
+ fileIO.closeSync(file2);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_append_file_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+});
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/symlink.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/symlink.test.js
similarity index 97%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/symlink.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/symlink.test.js
index e329b88c28a02326890a11b6ee865b3d4a925a88..9265721c62b7f5e82741bad4dc262264381f6549 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/symlink.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/members/symlink.test.js
@@ -1,266 +1,266 @@
-/*
- * Copyright (C) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the 'License');
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an 'AS IS' BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import featureAbility from '@ohos.ability.featureAbility';
-import {
- fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect,
-} from '../Common';
-
-export default function fileIOSymlink() {
-describe('fileIO_fs_symlink', function () {
-
- /**
- * @tc.number SUB_DF_FILEIO_SYMLINK_SYNC_0000
- * @tc.name fileIO_test_symlink_sync_000
- * @tc.desc Test symlinkSync() interfaces.
- * Create a symbolic link to verify normal function.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_symlink_sync_000', 0, async function () {
- let fpath = await nextFileName('fileIO_test_symlink_sync_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.symlinkSync(fpath, fpath + 'link0');
- expect(fileIO.accessSync(fpath + 'link0')).assertTrue();
- fileIO.unlinkSync(fpath);
- fileIO.unlinkSync(fpath + 'link0');
- } catch (e) {
- console.log('fileIO_test_symlink_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_SYMLINK_SYNC_0100
- * @tc.name fileIO_test_symlink_sync_001
- * @tc.desc Test symlinkSync() interfaces.
- * Missing parameter.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_symlink_sync_001', 0, async function () {
- let fpath = await nextFileName('fileIO_test_symlink_sync_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.symlinkSync(fpath);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_symlink_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_SYMLINK_SYNC_0200
- * @tc.name fileIO_test_symlink_sync_002
- * @tc.desc Test symlinkSync() interfaces.
- * Can't create a symbolic links in distributed directories.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_symlink_sync_002', 0, async function () {
- let dstDir = await featureAbility.getContext().getOrCreateDistributedDir();
- let fpath = await nextFileName('fileIO_test_symlink_sync_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.symlinkSync(fpath, dstDir + '/link_000');
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_symlink_sync_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900001 && e.message == 'Operation not permitted').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_SYMLINK_ASYNC_0000
- * @tc.name fileIO_test_symlink_async_000
- * @tc.desc Test SymlinkAsync interfaces. Promise.then().catch()
- * Create a symbolic link to verify normal function.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_symlink_async_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_symlink_async_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.symlink(fpath, fpath + 'link1').then(() => {
- expect(fileIO.accessSync(fpath + 'link1')).assertTrue();
- fileIO.unlinkSync(fpath);
- fileIO.unlinkSync(fpath + 'link1');
- }).catch((err) => {
- console.log('fileIO_test_symlink_async_000 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- })
- done();
- } catch (e) {
- console.log('fileIO_test_symlink_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_SYMLINK_ASYNC_0100
- * @tc.name fileIO_test_symlink_async_001
- * @tc.desc Test SymlinkAsync interfaces. await Promise.
- * Create a symbolic link to verify normal function.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_symlink_async_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_symlink_async_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- await fileIO.symlink(fpath, fpath + 'link2');
- expect(fileIO.accessSync(fpath + 'link2')).assertTrue();
- fileIO.unlinkSync(fpath);
- fileIO.unlinkSync(fpath + 'link2');
- done();
- } catch (e) {
- console.log('fileIO_test_symlink_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_SYMLINK_ASYNC_0200
- * @tc.name fileIO_test_symlink_async_002
- * @tc.desc Test SymlinkAsync interfaces. Promise.
- * Create a symbolic link to verify normal function.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_symlink_async_002', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_symlink_async_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.symlink(fpath, fpath + 'link3', (err) => {
- if (err) {
- console.log('fileIO_test_symlink_async_002 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(fileIO.accessSync(fpath + 'link3')).assertTrue();
- fileIO.unlinkSync(fpath);
- fileIO.unlinkSync(fpath + 'link3');
- done();
- });
- } catch (e) {
- console.log('fileIO_test_symlink_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_SYMLINK_ASYNC_0300
- * @tc.name fileIO_test_symlink_async_003
- * @tc.desc Test SymlinkAsync interfaces. Promise.
- * Missing parameter.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_symlink_async_003', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_symlink_async_003');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- await fileIO.symlink(fpath);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_symlink_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_SYMLINK_ASYNC_0400
- * @tc.name fileIO_test_symlink_async_004
- * @tc.desc Test symlink() interfaces.
- * Can't create a symbolic links in distributed directories.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_symlink_async_004', 0, async function (done) {
- let dstDir = await featureAbility.getContext().getOrCreateDistributedDir();
- let fpath = await nextFileName('fileIO_test_symlink_async_004');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- await fileIO.symlink(fpath, dstDir + '/link_001');
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_symlink_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900001 && e.message == 'Operation not permitted').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_SYMLINK_ASYNC_0500
- * @tc.name fileIO_test_symlink_async_005
- * @tc.desc Test symlink() interfaces.
- * Can't create a symbolic links in distributed directories.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_symlink_async_005', 0, async function (done) {
- let dstDir = await featureAbility.getContext().getOrCreateDistributedDir();
- let fpath = await nextFileName('fileIO_test_symlink_async_005');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.symlink(fpath, dstDir + '/link_002', (err) => {
- if (err) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_symlink_async_005 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900001 && err.message == 'Operation not permitted').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('fileIO_test_symlink_async_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-});
-}
+/*
+ * Copyright (C) 2023 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import featureAbility from '@ohos.ability.featureAbility';
+import {
+ fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect,
+} from '../Common';
+
+export default function fileIOSymlink() {
+describe('fileIO_fs_symlink', function () {
+
+ /**
+ * @tc.number SUB_DF_FILEIO_SYMLINK_SYNC_0000
+ * @tc.name fileIO_test_symlink_sync_000
+ * @tc.desc Test symlinkSync() interfaces.
+ * Create a symbolic link to verify normal function.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_symlink_sync_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_symlink_sync_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.symlinkSync(fpath, fpath + 'link0');
+ expect(fileIO.accessSync(fpath + 'link0')).assertTrue();
+ fileIO.unlinkSync(fpath);
+ fileIO.unlinkSync(fpath + 'link0');
+ } catch (e) {
+ console.log('fileIO_test_symlink_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_SYMLINK_SYNC_0100
+ * @tc.name fileIO_test_symlink_sync_001
+ * @tc.desc Test symlinkSync() interfaces.
+ * Missing parameter.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_symlink_sync_001', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_symlink_sync_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.symlinkSync(fpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_symlink_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_SYMLINK_SYNC_0200
+ * @tc.name fileIO_test_symlink_sync_002
+ * @tc.desc Test symlinkSync() interfaces.
+ * Can't create a symbolic links in distributed directories.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_symlink_sync_002', 0, async function () {
+ let dstDir = await featureAbility.getContext().getOrCreateDistributedDir();
+ let fpath = await nextFileName('fileIO_test_symlink_sync_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.symlinkSync(fpath, dstDir + '/link_000');
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_symlink_sync_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900001 && e.message == 'Operation not permitted').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_SYMLINK_ASYNC_0000
+ * @tc.name fileIO_test_symlink_async_000
+ * @tc.desc Test SymlinkAsync interfaces. Promise.then().catch()
+ * Create a symbolic link to verify normal function.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_symlink_async_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_symlink_async_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.symlink(fpath, fpath + 'link1').then(() => {
+ expect(fileIO.accessSync(fpath + 'link1')).assertTrue();
+ fileIO.unlinkSync(fpath);
+ fileIO.unlinkSync(fpath + 'link1');
+ }).catch((err) => {
+ console.log('fileIO_test_symlink_async_000 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ })
+ done();
+ } catch (e) {
+ console.log('fileIO_test_symlink_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_SYMLINK_ASYNC_0100
+ * @tc.name fileIO_test_symlink_async_001
+ * @tc.desc Test SymlinkAsync interfaces. await Promise.
+ * Create a symbolic link to verify normal function.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_symlink_async_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_symlink_async_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ await fileIO.symlink(fpath, fpath + 'link2');
+ expect(fileIO.accessSync(fpath + 'link2')).assertTrue();
+ fileIO.unlinkSync(fpath);
+ fileIO.unlinkSync(fpath + 'link2');
+ done();
+ } catch (e) {
+ console.log('fileIO_test_symlink_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_SYMLINK_ASYNC_0200
+ * @tc.name fileIO_test_symlink_async_002
+ * @tc.desc Test SymlinkAsync interfaces. Promise.
+ * Create a symbolic link to verify normal function.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_symlink_async_002', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_symlink_async_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.symlink(fpath, fpath + 'link3', (err) => {
+ if (err) {
+ console.log('fileIO_test_symlink_async_002 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(fileIO.accessSync(fpath + 'link3')).assertTrue();
+ fileIO.unlinkSync(fpath);
+ fileIO.unlinkSync(fpath + 'link3');
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_symlink_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_SYMLINK_ASYNC_0300
+ * @tc.name fileIO_test_symlink_async_003
+ * @tc.desc Test SymlinkAsync interfaces. Promise.
+ * Missing parameter.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_symlink_async_003', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_symlink_async_003');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ await fileIO.symlink(fpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_symlink_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_SYMLINK_ASYNC_0400
+ * @tc.name fileIO_test_symlink_async_004
+ * @tc.desc Test symlink() interfaces.
+ * Can't create a symbolic links in distributed directories.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_symlink_async_004', 0, async function (done) {
+ let dstDir = await featureAbility.getContext().getOrCreateDistributedDir();
+ let fpath = await nextFileName('fileIO_test_symlink_async_004');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ await fileIO.symlink(fpath, dstDir + '/link_001');
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_symlink_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900001 && e.message == 'Operation not permitted').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_SYMLINK_ASYNC_0500
+ * @tc.name fileIO_test_symlink_async_005
+ * @tc.desc Test symlink() interfaces.
+ * Can't create a symbolic links in distributed directories.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_symlink_async_005', 0, async function (done) {
+ let dstDir = await featureAbility.getContext().getOrCreateDistributedDir();
+ let fpath = await nextFileName('fileIO_test_symlink_async_005');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.symlink(fpath, dstDir + '/link_002', (err) => {
+ if (err) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_symlink_async_005 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900001 && err.message == 'Operation not permitted').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('fileIO_test_symlink_async_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+});
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/truncate.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/truncate.test.js
similarity index 97%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/truncate.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/truncate.test.js
index e943eee61764b4e835d415e490aa9ed8b0516a3a..4e292287faa283841694a2d176482553110d11af 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/truncate.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/members/truncate.test.js
@@ -1,483 +1,483 @@
-/*
- * Copyright (C) 2022 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the 'License');
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an 'AS IS' BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import {
- fileIO, FILE_CONTENT, prepareFile, nextFileName, isIntNum, describe, it, expect,
-} from '../Common';
-
- export default function fileIOTruncate() {
- describe('fileIO_fs_truncate', function () {
-
- /**
- * @tc.number SUB_DF_FILEIO_TRUNCATE_ASYNC_0000
- * @tc.name fileIO_truncate_async_000
- * @tc.desc Test the truncate() interface. Promise.
- * Truncate the file with path and truncateLen = 5.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_truncate_async_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_truncate_async_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let truncateLen = 5;
-
- try {
- await fileIO.truncate(fpath, truncateLen);
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
- expect(readLen == truncateLen).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_truncate_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_TRUNCATE_ASYNC_0100
- * @tc.name fileIO_truncate_async_001
- * @tc.desc Test the truncate() interface. Callback.
- * Truncate the file with fd and truncateLen = 5.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_truncate_async_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_truncate_async_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- let truncateLen = 5;
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.truncate(file.fd, truncateLen, (err) => {
- if(err) {
- console.log('fileIO_truncate_async_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
- expect(readLen == truncateLen).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_truncate_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_TRUNCATE_ASYNC_0200
- * @tc.name fileIO_truncate_async_002
- * @tc.desc Test the truncate() interface. Promise.then().catch
- * Truncate the file with path and truncateLen = 2.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_truncate_async_002', 0, async function (done) {
- let fpath = await nextFileName('fileIO_truncate_async_002');
- expect(prepareFile(fpath, 'truncate')).assertTrue();
- let truncateLen = 2;
-
- try {
- fileIO.truncate(fpath, truncateLen).then(() => {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
- expect(readLen == truncateLen).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- }).catch((err) => {
- console.log('fileIO_truncate_async_002 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- });
- } catch(e) {
- console.log('fileIO_truncate_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_TRUNCATE_ASYNC_0300
- * @tc.name fileIO_truncate_async_003
- * @tc.desc Test the truncate() interface. Promise.then().catch
- * Truncate the file with fd and truncateLen = 2.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_truncate_async_003', 0, async function (done) {
- let fpath = await nextFileName('fileIO_truncate_async_003');
- expect(prepareFile(fpath, 'truncate')).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- let truncateLen = 2;
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.truncate(file.fd, truncateLen).then(() => {
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
- expect(readLen == truncateLen).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- }).catch((err) => {
- console.log('fileIO_truncate_async_003 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- });
- } catch(e) {
- console.log('fileIO_truncate_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_TRUNCATE_ASYNC_0400
- * @tc.name fileIO_truncate_async_004
- * @tc.desc Test the truncate() interface. Callback.
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_truncate_async_004', 0, async function (done) {
- let fpath = await nextFileName('fileIO_truncate_async_004');
- let truncateLen = 2;
-
- try {
- fileIO.truncate(fpath, truncateLen, (err) => {
- if (err) {
- console.log('fileIO_truncate_async_004 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('fileIO_truncate_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_TRUNCATE_ASYNC_0500
- * @tc.name fileIO_truncate_async_005
- * @tc.desc Test the truncate() interface. Promise.
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_truncate_async_005', 0, async function (done) {
- let fpath = await nextFileName('fileIO_truncate_async_005');
- let truncateLen = 2;
-
- try {
- await fileIO.truncate(fpath, truncateLen);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_truncate_async_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_TRUNCATE_ASYNC_0600
- * @tc.name fileIO_truncate_async_006
- * @tc.desc Test the truncate() interface. Callback.
- * Truncate the file with fd and truncateLen = 0.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_truncate_async_006', 0, async function (done) {
- let fpath = await nextFileName('fileIO_truncate_async_006');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.truncate(file.fd, (err) => {
- if(err) {
- console.log('fileIO_truncate_async_006 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
- expect(readLen == 0).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_truncate_async_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_TRUNCATE_ASYNC_0700
- * @tc.name fileIO_truncate_async_007
- * @tc.desc Test the truncate() interface. Callback.
- * Truncate the file with fd and truncateLen = 0.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_truncate_async_007', 0, async function (done) {
- let fpath = await nextFileName('fileIO_truncate_async_007');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.truncate(fpath, (err) => {
- if(err) {
- console.log('fileIO_truncate_async_007 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
- expect(readLen == 0).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_truncate_async_008 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_TRUNCATE_ASYNC_0800
- * @tc.name fileIO_truncate_async_008
- * @tc.desc Test the truncate() interface. Promise.
- * Use default truncateLen = 0.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_truncate_async_008', 3, async function (done) {
- let fpath = await nextFileName('fileIO_truncate_async_008');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- await fileIO.truncate(fpath, undefined);
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
- expect(readLen == 0).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_truncate_async_008 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_TRUNCATE_ASYNC_0900
- * @tc.name fileIO_truncate_async_009
- * @tc.desc Test the truncate() interface. Callback.
- * Use default truncateLen = 0.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_truncate_async_009', 3, async function (done) {
- let fpath = await nextFileName('fileIO_truncate_async_009');
- expect(prepareFile(fpath, 'truncate')).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.truncate(file.fd, undefined, (err) => {
- if (err) {
- console.log('fileIO_truncate_async_009 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
- expect(readLen == 0).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch(e) {
- console.log('fileIO_truncate_async_009 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_TRUNCATE_SYNC_0000
- * @tc.name fileIO_test_truncate_sync_000
- * @tc.desc Test the truncateSync() interface.
- * Truncate the file with path.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_truncate_sync_000', 0, async function () {
- let fpath = await nextFileName('fileIO_test_truncate_sync_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.truncateSync(fpath);
- expect(fileIO.statSync(fpath).size == 0).assertTrue();
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_truncate_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_TRUNCATE_SYNC_0100
- * @tc.name fileIO_test_truncate_sync_001
- * @tc.desc Test the truncateSync() interface.
- * Truncate the file with fd and truncateLen = 5.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_truncate_sync_001', 0, async function () {
- let fpath = await nextFileName('fileIO_test_truncate_sync_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- let truncateLen = 5;
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.truncateSync(file.fd, truncateLen);
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
- expect(readLen == truncateLen).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_truncate_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_TRUNCATE_SYNC_0200
- * @tc.name fileIO_test_truncate_sync_002
- * @tc.desc Test the truncateSync() interface.
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_truncate_sync_002', 0, async function () {
- let fpath = await nextFileName('fileIO_test_truncate_sync_002');
-
- try {
- fileIO.truncateSync(fpath);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_truncate_sync_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_TRUNCATE_SYNC_0300
- * @tc.name fileIO_test_truncate_sync_003
- * @tc.desc Test the truncateSync() interface. Invalid parameter.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_truncate_sync_003', 0, async function () {
- let truncateLen = 2;
-
- try {
- fileIO.truncateSync(-1, truncateLen);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_truncate_sync_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_TRUNCATE_SYNC_0400
- * @tc.name fileIO_test_truncate_sync_004
- * @tc.desc Test truncateSync() interfaces. Missing parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_truncate_sync_004', 0, function () {
-
- try {
- fileIO.truncateSync();
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_truncate_sync_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_TRUNCATE_SYNC_0500
- * @tc.name fileIO_test_truncate_sync_005
- * @tc.desc Test truncateSync() interfaces.
- * Use default truncateLen = 0.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_truncate_sync_005', 3, async function () {
- let fpath = await nextFileName('fileIO_test_truncate_sync_005');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.truncateSync(file.fd, undefined);
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
- expect(readLen == 0).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_truncate_sync_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-})
-}
+/*
+ * Copyright (C) 2022 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import {
+ fileIO, FILE_CONTENT, prepareFile, nextFileName, isIntNum, describe, it, expect,
+} from '../Common';
+
+ export default function fileIOTruncate() {
+ describe('fileIO_fs_truncate', function () {
+
+ /**
+ * @tc.number SUB_DF_FILEIO_TRUNCATE_ASYNC_0000
+ * @tc.name fileIO_truncate_async_000
+ * @tc.desc Test the truncate() interface. Promise.
+ * Truncate the file with path and truncateLen = 5.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_truncate_async_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_truncate_async_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let truncateLen = 5;
+
+ try {
+ await fileIO.truncate(fpath, truncateLen);
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
+ expect(readLen == truncateLen).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_truncate_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_TRUNCATE_ASYNC_0100
+ * @tc.name fileIO_truncate_async_001
+ * @tc.desc Test the truncate() interface. Callback.
+ * Truncate the file with fd and truncateLen = 5.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_truncate_async_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_truncate_async_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ let truncateLen = 5;
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.truncate(file.fd, truncateLen, (err) => {
+ if(err) {
+ console.log('fileIO_truncate_async_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
+ expect(readLen == truncateLen).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_truncate_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_TRUNCATE_ASYNC_0200
+ * @tc.name fileIO_truncate_async_002
+ * @tc.desc Test the truncate() interface. Promise.then().catch
+ * Truncate the file with path and truncateLen = 2.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_truncate_async_002', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_truncate_async_002');
+ expect(prepareFile(fpath, 'truncate')).assertTrue();
+ let truncateLen = 2;
+
+ try {
+ fileIO.truncate(fpath, truncateLen).then(() => {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
+ expect(readLen == truncateLen).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ }).catch((err) => {
+ console.log('fileIO_truncate_async_002 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ });
+ } catch(e) {
+ console.log('fileIO_truncate_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_TRUNCATE_ASYNC_0300
+ * @tc.name fileIO_truncate_async_003
+ * @tc.desc Test the truncate() interface. Promise.then().catch
+ * Truncate the file with fd and truncateLen = 2.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_truncate_async_003', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_truncate_async_003');
+ expect(prepareFile(fpath, 'truncate')).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ let truncateLen = 2;
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.truncate(file.fd, truncateLen).then(() => {
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
+ expect(readLen == truncateLen).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ }).catch((err) => {
+ console.log('fileIO_truncate_async_003 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ });
+ } catch(e) {
+ console.log('fileIO_truncate_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_TRUNCATE_ASYNC_0400
+ * @tc.name fileIO_truncate_async_004
+ * @tc.desc Test the truncate() interface. Callback.
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_truncate_async_004', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_truncate_async_004');
+ let truncateLen = 2;
+
+ try {
+ fileIO.truncate(fpath, truncateLen, (err) => {
+ if (err) {
+ console.log('fileIO_truncate_async_004 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('fileIO_truncate_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_TRUNCATE_ASYNC_0500
+ * @tc.name fileIO_truncate_async_005
+ * @tc.desc Test the truncate() interface. Promise.
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_truncate_async_005', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_truncate_async_005');
+ let truncateLen = 2;
+
+ try {
+ await fileIO.truncate(fpath, truncateLen);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_truncate_async_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_TRUNCATE_ASYNC_0600
+ * @tc.name fileIO_truncate_async_006
+ * @tc.desc Test the truncate() interface. Callback.
+ * Truncate the file with fd and truncateLen = 0.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_truncate_async_006', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_truncate_async_006');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.truncate(file.fd, (err) => {
+ if(err) {
+ console.log('fileIO_truncate_async_006 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
+ expect(readLen == 0).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_truncate_async_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_TRUNCATE_ASYNC_0700
+ * @tc.name fileIO_truncate_async_007
+ * @tc.desc Test the truncate() interface. Callback.
+ * Truncate the file with fd and truncateLen = 0.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_truncate_async_007', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_truncate_async_007');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.truncate(fpath, (err) => {
+ if(err) {
+ console.log('fileIO_truncate_async_007 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
+ expect(readLen == 0).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_truncate_async_008 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_TRUNCATE_ASYNC_0800
+ * @tc.name fileIO_truncate_async_008
+ * @tc.desc Test the truncate() interface. Promise.
+ * Use default truncateLen = 0.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_truncate_async_008', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_truncate_async_008');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ await fileIO.truncate(fpath, undefined);
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
+ expect(readLen == 0).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_truncate_async_008 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_TRUNCATE_ASYNC_0900
+ * @tc.name fileIO_truncate_async_009
+ * @tc.desc Test the truncate() interface. Callback.
+ * Use default truncateLen = 0.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_truncate_async_009', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_truncate_async_009');
+ expect(prepareFile(fpath, 'truncate')).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.truncate(file.fd, undefined, (err) => {
+ if (err) {
+ console.log('fileIO_truncate_async_009 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
+ expect(readLen == 0).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch(e) {
+ console.log('fileIO_truncate_async_009 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_TRUNCATE_SYNC_0000
+ * @tc.name fileIO_test_truncate_sync_000
+ * @tc.desc Test the truncateSync() interface.
+ * Truncate the file with path.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_truncate_sync_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_truncate_sync_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.truncateSync(fpath);
+ expect(fileIO.statSync(fpath).size == 0).assertTrue();
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_truncate_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_TRUNCATE_SYNC_0100
+ * @tc.name fileIO_test_truncate_sync_001
+ * @tc.desc Test the truncateSync() interface.
+ * Truncate the file with fd and truncateLen = 5.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_truncate_sync_001', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_truncate_sync_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ let truncateLen = 5;
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.truncateSync(file.fd, truncateLen);
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
+ expect(readLen == truncateLen).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_truncate_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_TRUNCATE_SYNC_0200
+ * @tc.name fileIO_test_truncate_sync_002
+ * @tc.desc Test the truncateSync() interface.
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_truncate_sync_002', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_truncate_sync_002');
+
+ try {
+ fileIO.truncateSync(fpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_truncate_sync_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_TRUNCATE_SYNC_0300
+ * @tc.name fileIO_test_truncate_sync_003
+ * @tc.desc Test the truncateSync() interface. Invalid parameter.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_truncate_sync_003', 0, async function () {
+ let truncateLen = 2;
+
+ try {
+ fileIO.truncateSync(-1, truncateLen);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_truncate_sync_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_TRUNCATE_SYNC_0400
+ * @tc.name fileIO_test_truncate_sync_004
+ * @tc.desc Test truncateSync() interfaces. Missing parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_truncate_sync_004', 0, function () {
+
+ try {
+ fileIO.truncateSync();
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_truncate_sync_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_TRUNCATE_SYNC_0500
+ * @tc.name fileIO_test_truncate_sync_005
+ * @tc.desc Test truncateSync() interfaces.
+ * Use default truncateLen = 0.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_truncate_sync_005', 3, async function () {
+ let fpath = await nextFileName('fileIO_test_truncate_sync_005');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.truncateSync(file.fd, undefined);
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096));
+ expect(readLen == 0).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_truncate_sync_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+})
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/unlink.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/unlink.test.js
similarity index 96%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/unlink.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/unlink.test.js
index 13234919a079623069bc424dcb594597ae81a531..63397396d1df34a24207865f84e6ec6cb048ea97 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/unlink.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/members/unlink.test.js
@@ -1,297 +1,297 @@
-/*
- * Copyright (C) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the 'License');
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an 'AS IS' BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import {
- fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect,
-} from '../Common';
-
-export default function fileIOUnlink() {
-describe('fileIO_fs_unlink', function () {
-
- /**
- * @tc.number SUB_DF_FILEIO_UNLINK_SYNC_0000
- * @tc.name fileIO_test_unlink_sync_000
- * @tc.desc Test unlinkSync() interfaces.
- * Missing parameter.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_unlink_sync_000', 0, function () {
- try {
- fileIO.unlinkSync();
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_unlink_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_UNLINK_SYNC_0100
- * @tc.name fileIO_test_unlink_sync_001
- * @tc.desc Test unlinkSync() interfaces.
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_unlink_sync_001', 0, async function () {
- let fpath = await nextFileName('fileIOTest');
-
- try {
- fileIO.unlinkSync(fpath);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_unlink_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_UNLINK_SYNC_0200
- * @tc.name fileIO_test_unlink_sync_002
- * @tc.desc Test unlinkSync() interfaces.
- * Delete the file by path, verify the normal function.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_unlink_sync_002', 0, async function () {
- let fpath = await nextFileName('fileIO_test_unlink_sync_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- expect(fileIO.accessSync(fpath)).assertTrue();
- fileIO.unlinkSync(fpath);
- expect(!fileIO.accessSync(fpath)).assertTrue();
- } catch (e) {
- console.log('fileIO_test_unlink_sync_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_UNLINK_SYNC_0300
- * @tc.name fileIO_test_unlink_sync_003
- * @tc.desc Test unlinkSync() interfaces.
- * The path refers to a directory, not a file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_unlink_sync_003', 0, async function () {
- let dpath = await nextFileName('fileIO_test_unlink_sync_003');
- fileIO.mkdirSync(dpath);
-
- try {
- expect(fileIO.accessSync(dpath)).assertTrue();
- fileIO.unlinkSync(dpath);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.rmdirSync(dpath);
- console.log('fileIO_test_unlink_sync_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900019 && e.message == 'Is a directory').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FileIO_UNLINK_ASYNC_0000
- * @tc.name fileIO_test_unlink_async_000
- * @tc.desc Test unlinkAsync() interfaces. Promise.
- * Delete the file by path, verify the normal function.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_unlink_async_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_unlink_async_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- expect(fileIO.accessSync(fpath)).assertTrue();
- await fileIO.unlink(fpath);
- expect(!fileIO.accessSync(fpath)).assertTrue();
- done();
- } catch (e) {
- console.log('fileIO_test_unlink_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FileIO_UNLINK_ASYNC_0100
- * @tc.name fileIO_test_unlink_async_001
- * @tc.desc Test unlinkAsync() interfaces. Callback.
- * Delete the file by path, verify the normal function.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_unlink_async_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_unlink_async_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- expect(fileIO.accessSync(fpath)).assertTrue();
- fileIO.unlink(fpath, (err) => {
- if (err) {
- console.log('fileIO_test_unlink_async_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(!fileIO.accessSync(fpath)).assertTrue();
- done();
- });
- } catch (e) {
- console.log('fileIO_test_unlink_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FileIO_UNLINK_ASYNC_0200
- * @tc.name fileIO_test_unlink_async_002
- * @tc.desc Test unlink() interfaces. Callback.
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_unlink_async_002', 0, async function (done) {
- let fpath = await nextFileName('fileIOTest');
-
- try {
- fileIO.unlink(fpath, (err) => {
- if (err) {
- console.log('fileIO_test_unlink_async_002 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('fileIO_test_unlink_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FileIO_UNLINK_ASYNC_0300
- * @tc.name fileIO_test_unlink_async_003
- * @tc.desc Test unlink() interfaces. Promise.
- * The path point to nothing, no such file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_unlink_async_003', 0, async function (done) {
- let fpath = await nextFileName('fileIOTest');
-
- try {
- await fileIO.unlink(fpath);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_unlink_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FileIO_UNLINK_ASYNC_0400
- * @tc.name fileIO_test_unlink_async_004
- * @tc.desc Test unlink() interfaces. Promise.
- * Missing parameter.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_unlink_async_004', 0, async function (done) {
-
- try {
- await fileIO.unlink();
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_unlink_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_UNLINK_ASYNC_0500
- * @tc.name fileIO_test_unlink_async_005
- * @tc.desc Test unlink() interfaces. Promise.
- * The path refers to a directory, not a file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_unlink_async_005', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_unlink_async_005');
- fileIO.mkdirSync(dpath);
-
- try {
- expect(fileIO.accessSync(dpath)).assertTrue();
- await fileIO.unlink(dpath);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.rmdirSync(dpath);
- console.log('fileIO_test_unlink_async_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900019 && e.message == 'Is a directory').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_UNLINK_ASYNC_0600
- * @tc.name fileIO_test_unlink_async_006
- * @tc.desc Test unlink() interfaces. Callback.
- * The path refers to a directory, not a file.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_unlink_async_006', 0, async function (done) {
- let dpath = await nextFileName('fileIO_test_unlink_async_006');
- fileIO.mkdirSync(dpath);
-
- try {
- expect(fileIO.accessSync(dpath)).assertTrue();
- fileIO.unlink(dpath, (err) => {
- if (err) {
- fileIO.rmdirSync(dpath);
- console.log('fileIO_test_unlink_async_006 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900019 && err.message == 'Is a directory').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('fileIO_test_unlink_async_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-});
-}
+/*
+ * Copyright (C) 2023 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import {
+ fileIO, FILE_CONTENT, prepareFile, nextFileName, describe, it, expect,
+} from '../Common';
+
+export default function fileIOUnlink() {
+describe('fileIO_fs_unlink', function () {
+
+ /**
+ * @tc.number SUB_DF_FILEIO_UNLINK_SYNC_0000
+ * @tc.name fileIO_test_unlink_sync_000
+ * @tc.desc Test unlinkSync() interfaces.
+ * Missing parameter.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_unlink_sync_000', 0, function () {
+ try {
+ fileIO.unlinkSync();
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_unlink_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_UNLINK_SYNC_0100
+ * @tc.name fileIO_test_unlink_sync_001
+ * @tc.desc Test unlinkSync() interfaces.
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_unlink_sync_001', 0, async function () {
+ let fpath = await nextFileName('fileIOTest');
+
+ try {
+ fileIO.unlinkSync(fpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_unlink_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_UNLINK_SYNC_0200
+ * @tc.name fileIO_test_unlink_sync_002
+ * @tc.desc Test unlinkSync() interfaces.
+ * Delete the file by path, verify the normal function.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_unlink_sync_002', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_unlink_sync_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ expect(fileIO.accessSync(fpath)).assertTrue();
+ fileIO.unlinkSync(fpath);
+ expect(!fileIO.accessSync(fpath)).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_unlink_sync_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_UNLINK_SYNC_0300
+ * @tc.name fileIO_test_unlink_sync_003
+ * @tc.desc Test unlinkSync() interfaces.
+ * The path refers to a directory, not a file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_unlink_sync_003', 0, async function () {
+ let dpath = await nextFileName('fileIO_test_unlink_sync_003');
+ fileIO.mkdirSync(dpath);
+
+ try {
+ expect(fileIO.accessSync(dpath)).assertTrue();
+ fileIO.unlinkSync(dpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.rmdirSync(dpath);
+ console.log('fileIO_test_unlink_sync_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900019 && e.message == 'Is a directory').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FileIO_UNLINK_ASYNC_0000
+ * @tc.name fileIO_test_unlink_async_000
+ * @tc.desc Test unlinkAsync() interfaces. Promise.
+ * Delete the file by path, verify the normal function.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_unlink_async_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_unlink_async_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ expect(fileIO.accessSync(fpath)).assertTrue();
+ await fileIO.unlink(fpath);
+ expect(!fileIO.accessSync(fpath)).assertTrue();
+ done();
+ } catch (e) {
+ console.log('fileIO_test_unlink_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FileIO_UNLINK_ASYNC_0100
+ * @tc.name fileIO_test_unlink_async_001
+ * @tc.desc Test unlinkAsync() interfaces. Callback.
+ * Delete the file by path, verify the normal function.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_unlink_async_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_unlink_async_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ expect(fileIO.accessSync(fpath)).assertTrue();
+ fileIO.unlink(fpath, (err) => {
+ if (err) {
+ console.log('fileIO_test_unlink_async_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(!fileIO.accessSync(fpath)).assertTrue();
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_unlink_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FileIO_UNLINK_ASYNC_0200
+ * @tc.name fileIO_test_unlink_async_002
+ * @tc.desc Test unlink() interfaces. Callback.
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_unlink_async_002', 0, async function (done) {
+ let fpath = await nextFileName('fileIOTest');
+
+ try {
+ fileIO.unlink(fpath, (err) => {
+ if (err) {
+ console.log('fileIO_test_unlink_async_002 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('fileIO_test_unlink_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FileIO_UNLINK_ASYNC_0300
+ * @tc.name fileIO_test_unlink_async_003
+ * @tc.desc Test unlink() interfaces. Promise.
+ * The path point to nothing, no such file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_unlink_async_003', 0, async function (done) {
+ let fpath = await nextFileName('fileIOTest');
+
+ try {
+ await fileIO.unlink(fpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_unlink_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FileIO_UNLINK_ASYNC_0400
+ * @tc.name fileIO_test_unlink_async_004
+ * @tc.desc Test unlink() interfaces. Promise.
+ * Missing parameter.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_unlink_async_004', 0, async function (done) {
+
+ try {
+ await fileIO.unlink();
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_unlink_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_UNLINK_ASYNC_0500
+ * @tc.name fileIO_test_unlink_async_005
+ * @tc.desc Test unlink() interfaces. Promise.
+ * The path refers to a directory, not a file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_unlink_async_005', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_unlink_async_005');
+ fileIO.mkdirSync(dpath);
+
+ try {
+ expect(fileIO.accessSync(dpath)).assertTrue();
+ await fileIO.unlink(dpath);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.rmdirSync(dpath);
+ console.log('fileIO_test_unlink_async_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900019 && e.message == 'Is a directory').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_UNLINK_ASYNC_0600
+ * @tc.name fileIO_test_unlink_async_006
+ * @tc.desc Test unlink() interfaces. Callback.
+ * The path refers to a directory, not a file.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_unlink_async_006', 0, async function (done) {
+ let dpath = await nextFileName('fileIO_test_unlink_async_006');
+ fileIO.mkdirSync(dpath);
+
+ try {
+ expect(fileIO.accessSync(dpath)).assertTrue();
+ fileIO.unlink(dpath, (err) => {
+ if (err) {
+ fileIO.rmdirSync(dpath);
+ console.log('fileIO_test_unlink_async_006 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900019 && err.message == 'Is a directory').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('fileIO_test_unlink_async_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+});
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/write.test.js b/storage/storagefileiov9jstest/src/main/js/test/members/write.test.js
similarity index 97%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/write.test.js
rename to storage/storagefileiov9jstest/src/main/js/test/members/write.test.js
index e02157f90ae8987f9bb0271481d32f65b0845663..d54f43007f6077edc31a476749664a12af8725d4 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/test/members/write.test.js
+++ b/storage/storagefileiov9jstest/src/main/js/test/members/write.test.js
@@ -1,1235 +1,1235 @@
-/*
- * Copyright (C) 2022 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the 'License');
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an 'AS IS' BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import {
- fileIO, FILE_CONTENT, prepareFile, nextFileName, isIntNum, describe, it, expect,
-} from '../Common';
-
-export default function fileIOWrite() {
- describe('fileIO_fs_write', function () {
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_SYNC_0000
- * @tc.name fileIO_test_write_sync_000
- * @tc.desc Test writeSync() interfaces.
- * Open the file in write-only mode, default write from current offset.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_write_sync_000', 0, async function () {
- let fpath = await nextFileName('fileIO_test_write_sync_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- let bytesWritten1 = fileIO.writeSync(file.fd, FILE_CONTENT);
- expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
- let bytesWritten2 = fileIO.writeSync(file.fd, new ArrayBuffer(FILE_CONTENT.length));
- expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), { offset: 0 });
- expect(readLen == FILE_CONTENT.length * 2).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_write_sync_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_SYNC_0100
- * @tc.name fileIO_test_write_sync_001
- * @tc.desc Test writeSync() interfaces.
- * Open the file in write-only mode, writing a string with encoding = 'utf-8'.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_sync_001', 0, async function () {
- let fpath = await nextFileName('fileIO_test_write_sync_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let bytesWritten = fileIO.writeSync(file.fd, FILE_CONTENT, {
- encoding: 'utf-8',
- })
- expect(bytesWritten == FILE_CONTENT.length).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_write_sync_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_SYNC_0200
- * @tc.name fileIO_test_write_sync_002
- * @tc.desc Test writeSync() interfaces.
- * Open the file in write-only mode, writing a string from offset(position) = 1.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_sync_002', 0, async function () {
- let fpath = await nextFileName('fileIO_test_write_sync_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let bytesWritten = fileIO.writeSync(file.fd, FILE_CONTENT, {
- offset: 1,
- });
- expect(bytesWritten == FILE_CONTENT.length).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_write_sync_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_SYNC_0300
- * @tc.name fileIO_test_write_sync_003
- * @tc.desc Test writeSync() interfaces.
- * Open the file in write-only mode, writing a string of length = 1.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_sync_003', 0, async function () {
- let fpath = await nextFileName('fileIO_test_write_sync_003');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let bytesWritten = fileIO.writeSync(file.fd, FILE_CONTENT, {
- length: 1,
- });
- expect(bytesWritten == 1).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_write_sync_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_SYNC_0400
- * @tc.name fileIO_test_write_sync_004
- * @tc.desc Test writeSync() interfaces.
- * Open the file in write-only mode, writing a string of length = 1 and offset(position) = 1.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_sync_004', 0, async function () {
- let fpath = await nextFileName('fileIO_test_write_sync_004');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let bytesWritten = fileIO.writeSync(file.fd, FILE_CONTENT, {
- offset: 1,
- length: 1,
- });
- expect(bytesWritten == 1).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_write_sync_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_SYNC_0500
- * @tc.name fileIO_test_write_sync_005
- * @tc.desc Test writeSync() interfaces.
- * Open the file in write-only mode, writing a string of length = 1, offset(position) = 1, encoding = 'utf-8'.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_sync_005', 0, async function () {
- let fpath = await nextFileName('fileIO_test_write_sync_005');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let bytesWritten = fileIO.writeSync(file.fd, FILE_CONTENT, {
- offset: 1,
- length: 5,
- encoding: 'utf-8',
- });
- expect(bytesWritten == 5).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_write_sync_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_SYNC_0600
- * @tc.name fileIO_test_write_sync_006
- * @tc.desc Test writeSync() interfaces.
- * Write with invalid 'length' option.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_sync_006', 0, async function () {
- let fpath = await nextFileName('fileIO_test_write_sync_006');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- const invalidLength = 9999;
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.writeSync(file.fd, FILE_CONTENT, { length: invalidLength })
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_write_sync_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_SYNC_0700
- * @tc.name fileIO_test_write_sync_007
- * @tc.desc Test writeSync() interfaces.
- * Write with invalid fd parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_sync_007', 0, function () {
-
- try {
- fileIO.writeSync(-1, FILE_CONTENT);
- expect(false).assertTrue();
- } catch (e) {
- console.log('fileIO_test_write_sync_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_SYNC_0800
- * @tc.name fileIO_test_write_sync_008
- * @tc.desc Test writeSync() interfaces.
- * Open the file in write-only mode, writing an ArrayBuffer(4096).
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_sync_008', 0, async function () {
- let fpath = await nextFileName('fileIO_test_write_sync_008');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let bytesWritten = fileIO.writeSync(file.fd, new ArrayBuffer(4096));
- expect(bytesWritten == 4096).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_write_sync_008 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_SYNC_0900
- * @tc.name fileIO_test_write_sync_009
- * @tc.desc Test writeSync() interfaces.
- * Write with invalid 'length' option.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_sync_009', 0, async function () {
- let fpath = await nextFileName('fileIO_test_write_sync_009');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- const invalidLength = 4097;
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.writeSync(file.fd, new ArrayBuffer(4096), { length: invalidLength })
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_write_sync_009 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_SYNC_1000
- * @tc.name fileIO_test_write_sync_010
- * @tc.desc Test writeSync() interfaces.
- * Write with invalid 'offset' option.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_sync_010', 0, async function () {
- let fpath = await nextFileName('fileIO_test_write_sync_010');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- const invalidOffset = -1;
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.writeSync(file.fd, FILE_CONTENT, { offset: invalidOffset });
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_write_sync_010 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_SYNC_1100
- * @tc.name fileIO_test_write_sync_011
- * @tc.desc Test writeSync() interfaces.
- * Undefined option arguments, use default options.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_sync_011', 3, async function () {
- let fpath = await nextFileName('fileIO_test_write_sync_011');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- let bytesWritten1 = fileIO.writeSync(file.fd, FILE_CONTENT, undefined);
- expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
- let bytesWritten2 = fileIO.writeSync(file.fd, new ArrayBuffer(FILE_CONTENT.length), undefined);
- expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), { offset: 0 });
- expect(readLen == FILE_CONTENT.length * 2).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_write_sync_011 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_SYNC_1200
- * @tc.name fileIO_test_write_sync_012
- * @tc.desc Test writeSync() interfaces.
- * Undefined option arguments, use default options.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_sync_012', 3, async function () {
- let fpath = await nextFileName('fileIO_test_write_sync_012');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- let bytesWritten1 = fileIO.writeSync(file.fd, FILE_CONTENT, {
- offset: undefined,
- length: undefined,
- encoding: undefined,
- });
- expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
- let bytesWritten2 = fileIO.writeSync(file.fd, new ArrayBuffer(FILE_CONTENT.length), {
- offset: undefined,
- length: undefined,
- encoding: undefined,
- });
- expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), { offset: 0 });
- expect(readLen == FILE_CONTENT.length * 2).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- } catch (e) {
- console.log('fileIO_test_write_sync_012 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_0000
- * @tc.name fileIO_test_write_async_000
- * @tc.desc Test write() interfaces. Promise.
- * Open the file in write-only mode, default write from current offset.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 0
- * @tc.require
- */
- it('fileIO_test_write_async_000', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_write_async_000');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- let bytesWritten1 = await fileIO.write(file.fd, FILE_CONTENT);
- expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
- let bytesWritten2 = await fileIO.write(file.fd, new ArrayBuffer(FILE_CONTENT.length));
- expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), { offset: 0 });
- expect(readLen == FILE_CONTENT.length * 2).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_write_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_0100
- * @tc.name fileIO_test_write_async_001
- * @tc.desc Test write() interfaces. Callback.
- * Open the file in write-only mode, default write from current offset.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_async_001', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_write_async_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.write(file.fd, FILE_CONTENT, (err, bytesWritten1) => {
- if (err) {
- console.log('fileIO_test_write_async_001 err package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
- fileIO.write(file.fd, new ArrayBuffer(FILE_CONTENT.length), (err, bytesWritten2) => {
- if (err) {
- console.log('fileIO_test_write_async_001 err package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), { offset: 0 });
- expect(readLen == FILE_CONTENT.length * 2).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- });
- } catch (e) {
- console.log('fileIO_test_write_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_0200
- * @tc.name fileIO_test_write_async_002
- * @tc.desc Test write() interfaces. Promise.
- * Open the file in read-only mode, verifying that it is not writable.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_async_002', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_write_async_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- await fileIO.write(file.fd, FILE_CONTENT);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_write_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900008 && e.message == 'Bad file descriptor').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_0300
- * @tc.name fileIO_test_write_async_003
- * @tc.desc Test write() interfaces. Callback.
- * Open the file in read-only mode, verifying that it is not writable.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_async_003', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_write_async_003');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.write(file.fd, FILE_CONTENT, (err) => {
- if(err) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_write_async_003 error: {message: ' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900008 && err.message == 'Bad file descriptor').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('fileIO_test_write_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_0400
- * @tc.name fileIO_test_write_async_004
- * @tc.desc Test write() interfaces. Promise.
- * Open the file in write-only mode, writing a string of length = 3.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_async_004', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_write_async_004');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let bytesWritten = await fileIO.write(file.fd, FILE_CONTENT, {
- length: 3,
- });
- expect(bytesWritten == 3).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_write_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_0500
- * @tc.name fileIO_test_write_async_005
- * @tc.desc Test write() interfaces. Callback.
- * Open the file in write-only mode, writing a string of length = 3.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_async_005', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_write_async_005');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.write(file.fd, FILE_CONTENT, {
- length: 3,
- }, (err, bytesWritten) => {
- if(err) {
- console.log('fileIO_test_write_async_005 err package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(bytesWritten == 3).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_write_async_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_0600
- * @tc.name fileIO_test_write_async_006
- * @tc.desc Test write() interfaces. Promise.
- * Open the file in write-only mode, writing a string from offset(position) = 5.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_async_006', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_write_async_006');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let bytesWritten = await fileIO.write(file.fd, FILE_CONTENT, {
- offset: 5,
- });
- expect(bytesWritten == FILE_CONTENT.length).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_write_async_006 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_0700
- * @tc.name fileIO_test_write_async_007
- * @tc.desc Test write() interfaces. Callback.
- * Open the file in write-only mode, writing a string from offset(position) = 5.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_async_007', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_write_async_007');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.write(file.fd, FILE_CONTENT, {
- offset: 5,
- }, (err, bytesWritten) => {
- if(err) {
- console.log('fileIO_test_write_async_007 err package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(bytesWritten == FILE_CONTENT.length).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_write_async_007 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_0800
- * @tc.name fileIO_test_write_async_008
- * @tc.desc Test write() interfaces. Promise.
- * Open the file in write-only mode, writing a string of with length = 3 and offset = 5.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_async_008', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_write_async_008');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let bytesWritten = await fileIO.write(file.fd, FILE_CONTENT, {
- length: 3,
- offset: 5,
- });
- expect(bytesWritten == 3).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_write_async_008 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_0900
- * @tc.name fileIO_test_write_async_009
- * @tc.desc Test write() interfaces. Callback.
- * Open the file in write-only mode, writing a string of with length = 3 and offset = 5.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_async_009', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_write_async_009');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.write(file.fd, FILE_CONTENT, {
- length: 3,
- offset: 5,
- }, (err, bytesWritten) => {
- if(err) {
- console.log('fileIO_test_write_async_009 err package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(bytesWritten == 3).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_write_async_009 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_1000
- * @tc.name fileIO_test_write_async_010
- * @tc.desc Test write() interfaces.
- * Open the file in write-only mode, writing a string of with length = 3, offset = 5 and encoding = 'utf-8'.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_async_010', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_write_async_010');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let bytesWritten = await fileIO.write(file.fd, FILE_CONTENT, {
- length: 4,
- offset: 5,
- encoding: 'utf-8',
- });
- expect(bytesWritten == 4).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_write_async_010 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_1100
- * @tc.name fileIO_test_write_async_011
- * @tc.desc Test write() interfaces. Callback.
- * Open the file in write-only mode, writing a string of with length = 3, offset = 5 and encoding = 'utf-8'.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_async_011', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_write_async_011');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.write(file.fd, FILE_CONTENT, {
- length: 5,
- offset: 5,
- encoding: 'utf-8',
- }, (err, bytesWritten) => {
- if(err) {
- console.log('fileIO_test_write_async_011 err package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(bytesWritten == 5).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_write_async_011 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_1200
- * @tc.name fileIO_test_write_async_012
- * @tc.desc Test write() interfaces. Promise.
- * Open the file in write-only mode, writing an ArrayBuffer(4096).
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_async_012', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_write_async_012');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let bytesWritten = await fileIO.write(file.fd, new ArrayBuffer(4096));
- expect(bytesWritten == 4096).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_write_async_012 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_1300
- * @tc.name fileIO_test_write_async_013
- * @tc.desc Test write() interfaces. Callback.
- * Open the file in write-only mode, writing an ArrayBuffer(4096).
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_async_013', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_write_async_013');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.write(file.fd, new ArrayBuffer(4096), (err, bytesWritten) => {
- if(err) {
- console.log('fileIO_test_write_async_013 err package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(bytesWritten == 4096).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_write_async_013 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_1400
- * @tc.name fileIO_test_write_async_014
- * @tc.desc Test write() interfaces. Promise.
- * Open the file in write-only mode, writing a string with empty option parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_async_014', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_write_async_014');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- let bytesWritten = await fileIO.write(file.fd, FILE_CONTENT, {});
- expect(bytesWritten == FILE_CONTENT.length).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_write_async_014 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_1500
- * @tc.name fileIO_test_write_async_015
- * @tc.desc Test write() interfaces. Callback.
- * Open the file in write-only mode, writing a string with empty option parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_async_015', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_write_async_015');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.write(file.fd, new ArrayBuffer(4096), {
- }, (err, bytesWritten) => {
- if(err) {
- console.log('fileIO_test_write_async_015 err package ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(bytesWritten == 4096).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- } catch (e) {
- console.log('fileIO_test_write_async_015 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_1600
- * @tc.name fileIO_test_write_async_016
- * @tc.desc Test write() interfaces. Promise.
- * Write with invalid fd parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_async_016', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_write_async_016');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- await fileIO.write(-1, FILE_CONTENT);
- expect(false).assertTrue();
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_write_async_016 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_1700
- * @tc.name fileIO_test_write_async_017
- * @tc.desc Test write() interfaces. Callback.
- * Write with invalid fd parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_async_017', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_write_async_017');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- fileIO.write(-1, FILE_CONTENT, (err) => {
- expect(false).assertTrue();
- });
- } catch (e) {
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_write_async_017 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_1800
- * @tc.name fileIO_test_write_async_018
- * @tc.desc Test write() interfaces. Callback.
- * Write with invalid length parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_async_018', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_write_async_018');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- const invalidLength = 9999;
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.write(file.fd, FILE_CONTENT, {
- length: invalidLength,
- }, (err) => {
- expect(false).assertTrue();
- });
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_write_async_018 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_1900
- * @tc.name fileIO_test_write_async_019
- * @tc.desc Test write() interfaces. Callback.
- * Write with invalid length parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_async_019', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_write_async_019');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- const invalidLength = 4097;
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.write(file.fd, new ArrayBuffer(4096), {
- length: invalidLength,
- }, (err) => {
- expect(false).assertTrue();
- });
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_write_async_019 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_2000
- * @tc.name fileIO_test_write_async_020
- * @tc.desc Test write() interfaces. Callback.
- * Write with invalid length parameters.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_async_020', 0, async function (done) {
- let fpath = await nextFileName('fileIO_test_write_async_020');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
- const invalidOffset = -1;
-
- try {
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.write(file.fd, FILE_CONTENT, {
- offset: invalidOffset,
- }, (err) => {
- expect(false).assertTrue();
- });
- } catch (e) {
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- console.log('fileIO_test_write_async_020 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_2100
- * @tc.name fileIO_test_write_async_021
- * @tc.desc Test write() interfaces. Promise.
- * Undefined option arguments, use default options.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_async_021', 3, async function (done) {
- let fpath = await nextFileName('fileIO_test_write_async_021');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- let bytesWritten1 = await fileIO.write(file.fd, FILE_CONTENT, undefined);
- expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
- let bytesWritten2 = await fileIO.write(file.fd, new ArrayBuffer(FILE_CONTENT.length), undefined);
- expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), { offset: 0 });
- expect(readLen == FILE_CONTENT.length * 2).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_write_async_021 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_2200
- * @tc.name fileIO_test_write_async_022
- * @tc.desc Test write() interfaces. Callback.
- * Undefined option arguments, use default options.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_async_022', 3, async function (done) {
- let fpath = await nextFileName('fileIO_test_write_async_022');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.write(file.fd, FILE_CONTENT, undefined, (err, bytesWritten1) => {
- if (err) {
- console.log('fileIO_test_write_async_022 err package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
- fileIO.write(file.fd, new ArrayBuffer(FILE_CONTENT.length), undefined, (err, bytesWritten2) => {
- if (err) {
- console.log('fileIO_test_write_async_022 err package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), { offset: 0 });
- expect(readLen == FILE_CONTENT.length * 2).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- });
- } catch (e) {
- console.log('fileIO_test_write_async_022 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_2300
- * @tc.name fileIO_test_write_async_023
- * @tc.desc Test write() interfaces. Promise.
- * Undefined option arguments, use default options.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_async_023', 3, async function (done) {
- let fpath = await nextFileName('fileIO_test_write_async_023');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- let bytesWritten1 = await fileIO.write(file.fd, FILE_CONTENT, {
- length: undefined,
- offset: undefined,
- encoding: undefined,
- });
- expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
- let bytesWritten2 = await fileIO.write(file.fd, new ArrayBuffer(FILE_CONTENT.length), {
- length: undefined,
- offset: undefined,
- encoding: undefined,
- });
- expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), { offset: 0 });
- expect(readLen == FILE_CONTENT.length * 2).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- } catch (e) {
- console.log('fileIO_test_write_async_023 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_2400
- * @tc.name fileIO_test_write_async_024
- * @tc.desc Test write() interfaces. Callback.
- * Undefined option arguments, use default options.
- * @tc.size MEDIUM
- * @tc.type Functoin
- * @tc.level Level 3
- * @tc.require
- */
- it('fileIO_test_write_async_024', 3, async function (done) {
- let fpath = await nextFileName('fileIO_test_write_async_024');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
-
- try {
- let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
- expect(isIntNum(file.fd)).assertTrue();
- fileIO.write(file.fd, FILE_CONTENT, {
- length: undefined,
- offset: undefined,
- encoding: undefined,
- }, (err, bytesWritten1) => {
- if (err) {
- console.log('fileIO_test_write_async_011 err package1: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
- fileIO.write(file.fd, new ArrayBuffer(FILE_CONTENT.length), {
- length: undefined,
- offset: undefined,
- encoding: undefined,
- }, (err, bytesWritten2) => {
- if (err) {
- console.log('fileIO_test_write_async_005 err package2: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
- let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), { offset: 0 });
- expect(readLen == FILE_CONTENT.length * 2).assertTrue();
- fileIO.closeSync(file);
- fileIO.unlinkSync(fpath);
- done();
- });
- });
- } catch (e) {
- console.log('fileIO_test_write_async_024 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-})
-}
+/*
+ * Copyright (C) 2022 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import {
+ fileIO, FILE_CONTENT, prepareFile, nextFileName, isIntNum, describe, it, expect,
+} from '../Common';
+
+export default function fileIOWrite() {
+ describe('fileIO_fs_write', function () {
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_SYNC_0000
+ * @tc.name fileIO_test_write_sync_000
+ * @tc.desc Test writeSync() interfaces.
+ * Open the file in write-only mode, default write from current offset.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_write_sync_000', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_write_sync_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ let bytesWritten1 = fileIO.writeSync(file.fd, FILE_CONTENT);
+ expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
+ let bytesWritten2 = fileIO.writeSync(file.fd, new ArrayBuffer(FILE_CONTENT.length));
+ expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), { offset: 0 });
+ expect(readLen == FILE_CONTENT.length * 2).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_write_sync_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_SYNC_0100
+ * @tc.name fileIO_test_write_sync_001
+ * @tc.desc Test writeSync() interfaces.
+ * Open the file in write-only mode, writing a string with encoding = 'utf-8'.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_sync_001', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_write_sync_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let bytesWritten = fileIO.writeSync(file.fd, FILE_CONTENT, {
+ encoding: 'utf-8',
+ })
+ expect(bytesWritten == FILE_CONTENT.length).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_write_sync_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_SYNC_0200
+ * @tc.name fileIO_test_write_sync_002
+ * @tc.desc Test writeSync() interfaces.
+ * Open the file in write-only mode, writing a string from offset(position) = 1.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_sync_002', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_write_sync_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let bytesWritten = fileIO.writeSync(file.fd, FILE_CONTENT, {
+ offset: 1,
+ });
+ expect(bytesWritten == FILE_CONTENT.length).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_write_sync_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_SYNC_0300
+ * @tc.name fileIO_test_write_sync_003
+ * @tc.desc Test writeSync() interfaces.
+ * Open the file in write-only mode, writing a string of length = 1.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_sync_003', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_write_sync_003');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let bytesWritten = fileIO.writeSync(file.fd, FILE_CONTENT, {
+ length: 1,
+ });
+ expect(bytesWritten == 1).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_write_sync_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_SYNC_0400
+ * @tc.name fileIO_test_write_sync_004
+ * @tc.desc Test writeSync() interfaces.
+ * Open the file in write-only mode, writing a string of length = 1 and offset(position) = 1.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_sync_004', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_write_sync_004');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let bytesWritten = fileIO.writeSync(file.fd, FILE_CONTENT, {
+ offset: 1,
+ length: 1,
+ });
+ expect(bytesWritten == 1).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_write_sync_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_SYNC_0500
+ * @tc.name fileIO_test_write_sync_005
+ * @tc.desc Test writeSync() interfaces.
+ * Open the file in write-only mode, writing a string of length = 1, offset(position) = 1, encoding = 'utf-8'.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_sync_005', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_write_sync_005');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let bytesWritten = fileIO.writeSync(file.fd, FILE_CONTENT, {
+ offset: 1,
+ length: 5,
+ encoding: 'utf-8',
+ });
+ expect(bytesWritten == 5).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_write_sync_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_SYNC_0600
+ * @tc.name fileIO_test_write_sync_006
+ * @tc.desc Test writeSync() interfaces.
+ * Write with invalid 'length' option.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_sync_006', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_write_sync_006');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ const invalidLength = 9999;
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.writeSync(file.fd, FILE_CONTENT, { length: invalidLength })
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_write_sync_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_SYNC_0700
+ * @tc.name fileIO_test_write_sync_007
+ * @tc.desc Test writeSync() interfaces.
+ * Write with invalid fd parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_sync_007', 0, function () {
+
+ try {
+ fileIO.writeSync(-1, FILE_CONTENT);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('fileIO_test_write_sync_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_SYNC_0800
+ * @tc.name fileIO_test_write_sync_008
+ * @tc.desc Test writeSync() interfaces.
+ * Open the file in write-only mode, writing an ArrayBuffer(4096).
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_sync_008', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_write_sync_008');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let bytesWritten = fileIO.writeSync(file.fd, new ArrayBuffer(4096));
+ expect(bytesWritten == 4096).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_write_sync_008 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_SYNC_0900
+ * @tc.name fileIO_test_write_sync_009
+ * @tc.desc Test writeSync() interfaces.
+ * Write with invalid 'length' option.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_sync_009', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_write_sync_009');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ const invalidLength = 4097;
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.writeSync(file.fd, new ArrayBuffer(4096), { length: invalidLength })
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_write_sync_009 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_SYNC_1000
+ * @tc.name fileIO_test_write_sync_010
+ * @tc.desc Test writeSync() interfaces.
+ * Write with invalid 'offset' option.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_sync_010', 0, async function () {
+ let fpath = await nextFileName('fileIO_test_write_sync_010');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ const invalidOffset = -1;
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.writeSync(file.fd, FILE_CONTENT, { offset: invalidOffset });
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_write_sync_010 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_SYNC_1100
+ * @tc.name fileIO_test_write_sync_011
+ * @tc.desc Test writeSync() interfaces.
+ * Undefined option arguments, use default options.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_sync_011', 3, async function () {
+ let fpath = await nextFileName('fileIO_test_write_sync_011');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ let bytesWritten1 = fileIO.writeSync(file.fd, FILE_CONTENT, undefined);
+ expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
+ let bytesWritten2 = fileIO.writeSync(file.fd, new ArrayBuffer(FILE_CONTENT.length), undefined);
+ expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), { offset: 0 });
+ expect(readLen == FILE_CONTENT.length * 2).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_write_sync_011 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_SYNC_1200
+ * @tc.name fileIO_test_write_sync_012
+ * @tc.desc Test writeSync() interfaces.
+ * Undefined option arguments, use default options.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_sync_012', 3, async function () {
+ let fpath = await nextFileName('fileIO_test_write_sync_012');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ let bytesWritten1 = fileIO.writeSync(file.fd, FILE_CONTENT, {
+ offset: undefined,
+ length: undefined,
+ encoding: undefined,
+ });
+ expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
+ let bytesWritten2 = fileIO.writeSync(file.fd, new ArrayBuffer(FILE_CONTENT.length), {
+ offset: undefined,
+ length: undefined,
+ encoding: undefined,
+ });
+ expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), { offset: 0 });
+ expect(readLen == FILE_CONTENT.length * 2).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ } catch (e) {
+ console.log('fileIO_test_write_sync_012 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_0000
+ * @tc.name fileIO_test_write_async_000
+ * @tc.desc Test write() interfaces. Promise.
+ * Open the file in write-only mode, default write from current offset.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('fileIO_test_write_async_000', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_write_async_000');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ let bytesWritten1 = await fileIO.write(file.fd, FILE_CONTENT);
+ expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
+ let bytesWritten2 = await fileIO.write(file.fd, new ArrayBuffer(FILE_CONTENT.length));
+ expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), { offset: 0 });
+ expect(readLen == FILE_CONTENT.length * 2).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_write_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_0100
+ * @tc.name fileIO_test_write_async_001
+ * @tc.desc Test write() interfaces. Callback.
+ * Open the file in write-only mode, default write from current offset.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_async_001', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_write_async_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.write(file.fd, FILE_CONTENT, (err, bytesWritten1) => {
+ if (err) {
+ console.log('fileIO_test_write_async_001 err package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
+ fileIO.write(file.fd, new ArrayBuffer(FILE_CONTENT.length), (err, bytesWritten2) => {
+ if (err) {
+ console.log('fileIO_test_write_async_001 err package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), { offset: 0 });
+ expect(readLen == FILE_CONTENT.length * 2).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ });
+ } catch (e) {
+ console.log('fileIO_test_write_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_0200
+ * @tc.name fileIO_test_write_async_002
+ * @tc.desc Test write() interfaces. Promise.
+ * Open the file in read-only mode, verifying that it is not writable.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_async_002', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_write_async_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ await fileIO.write(file.fd, FILE_CONTENT);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_write_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900008 && e.message == 'Bad file descriptor').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_0300
+ * @tc.name fileIO_test_write_async_003
+ * @tc.desc Test write() interfaces. Callback.
+ * Open the file in read-only mode, verifying that it is not writable.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_async_003', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_write_async_003');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_ONLY);
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.write(file.fd, FILE_CONTENT, (err) => {
+ if(err) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_write_async_003 error: {message: ' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900008 && err.message == 'Bad file descriptor').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('fileIO_test_write_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_0400
+ * @tc.name fileIO_test_write_async_004
+ * @tc.desc Test write() interfaces. Promise.
+ * Open the file in write-only mode, writing a string of length = 3.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_async_004', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_write_async_004');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let bytesWritten = await fileIO.write(file.fd, FILE_CONTENT, {
+ length: 3,
+ });
+ expect(bytesWritten == 3).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_write_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_0500
+ * @tc.name fileIO_test_write_async_005
+ * @tc.desc Test write() interfaces. Callback.
+ * Open the file in write-only mode, writing a string of length = 3.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_async_005', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_write_async_005');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.write(file.fd, FILE_CONTENT, {
+ length: 3,
+ }, (err, bytesWritten) => {
+ if(err) {
+ console.log('fileIO_test_write_async_005 err package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(bytesWritten == 3).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_write_async_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_0600
+ * @tc.name fileIO_test_write_async_006
+ * @tc.desc Test write() interfaces. Promise.
+ * Open the file in write-only mode, writing a string from offset(position) = 5.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_async_006', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_write_async_006');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let bytesWritten = await fileIO.write(file.fd, FILE_CONTENT, {
+ offset: 5,
+ });
+ expect(bytesWritten == FILE_CONTENT.length).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_write_async_006 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_0700
+ * @tc.name fileIO_test_write_async_007
+ * @tc.desc Test write() interfaces. Callback.
+ * Open the file in write-only mode, writing a string from offset(position) = 5.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_async_007', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_write_async_007');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.write(file.fd, FILE_CONTENT, {
+ offset: 5,
+ }, (err, bytesWritten) => {
+ if(err) {
+ console.log('fileIO_test_write_async_007 err package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(bytesWritten == FILE_CONTENT.length).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_write_async_007 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_0800
+ * @tc.name fileIO_test_write_async_008
+ * @tc.desc Test write() interfaces. Promise.
+ * Open the file in write-only mode, writing a string of with length = 3 and offset = 5.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_async_008', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_write_async_008');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let bytesWritten = await fileIO.write(file.fd, FILE_CONTENT, {
+ length: 3,
+ offset: 5,
+ });
+ expect(bytesWritten == 3).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_write_async_008 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_0900
+ * @tc.name fileIO_test_write_async_009
+ * @tc.desc Test write() interfaces. Callback.
+ * Open the file in write-only mode, writing a string of with length = 3 and offset = 5.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_async_009', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_write_async_009');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.write(file.fd, FILE_CONTENT, {
+ length: 3,
+ offset: 5,
+ }, (err, bytesWritten) => {
+ if(err) {
+ console.log('fileIO_test_write_async_009 err package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(bytesWritten == 3).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_write_async_009 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_1000
+ * @tc.name fileIO_test_write_async_010
+ * @tc.desc Test write() interfaces.
+ * Open the file in write-only mode, writing a string of with length = 3, offset = 5 and encoding = 'utf-8'.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_async_010', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_write_async_010');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let bytesWritten = await fileIO.write(file.fd, FILE_CONTENT, {
+ length: 4,
+ offset: 5,
+ encoding: 'utf-8',
+ });
+ expect(bytesWritten == 4).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_write_async_010 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_1100
+ * @tc.name fileIO_test_write_async_011
+ * @tc.desc Test write() interfaces. Callback.
+ * Open the file in write-only mode, writing a string of with length = 3, offset = 5 and encoding = 'utf-8'.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_async_011', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_write_async_011');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.write(file.fd, FILE_CONTENT, {
+ length: 5,
+ offset: 5,
+ encoding: 'utf-8',
+ }, (err, bytesWritten) => {
+ if(err) {
+ console.log('fileIO_test_write_async_011 err package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(bytesWritten == 5).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_write_async_011 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_1200
+ * @tc.name fileIO_test_write_async_012
+ * @tc.desc Test write() interfaces. Promise.
+ * Open the file in write-only mode, writing an ArrayBuffer(4096).
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_async_012', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_write_async_012');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let bytesWritten = await fileIO.write(file.fd, new ArrayBuffer(4096));
+ expect(bytesWritten == 4096).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_write_async_012 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_1300
+ * @tc.name fileIO_test_write_async_013
+ * @tc.desc Test write() interfaces. Callback.
+ * Open the file in write-only mode, writing an ArrayBuffer(4096).
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_async_013', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_write_async_013');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.write(file.fd, new ArrayBuffer(4096), (err, bytesWritten) => {
+ if(err) {
+ console.log('fileIO_test_write_async_013 err package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(bytesWritten == 4096).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_write_async_013 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_1400
+ * @tc.name fileIO_test_write_async_014
+ * @tc.desc Test write() interfaces. Promise.
+ * Open the file in write-only mode, writing a string with empty option parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_async_014', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_write_async_014');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ let bytesWritten = await fileIO.write(file.fd, FILE_CONTENT, {});
+ expect(bytesWritten == FILE_CONTENT.length).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_write_async_014 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_1500
+ * @tc.name fileIO_test_write_async_015
+ * @tc.desc Test write() interfaces. Callback.
+ * Open the file in write-only mode, writing a string with empty option parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_async_015', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_write_async_015');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.write(file.fd, new ArrayBuffer(4096), {
+ }, (err, bytesWritten) => {
+ if(err) {
+ console.log('fileIO_test_write_async_015 err package ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(bytesWritten == 4096).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ } catch (e) {
+ console.log('fileIO_test_write_async_015 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_1600
+ * @tc.name fileIO_test_write_async_016
+ * @tc.desc Test write() interfaces. Promise.
+ * Write with invalid fd parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_async_016', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_write_async_016');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ await fileIO.write(-1, FILE_CONTENT);
+ expect(false).assertTrue();
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_write_async_016 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_1700
+ * @tc.name fileIO_test_write_async_017
+ * @tc.desc Test write() interfaces. Callback.
+ * Write with invalid fd parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_async_017', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_write_async_017');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ fileIO.write(-1, FILE_CONTENT, (err) => {
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_write_async_017 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_1800
+ * @tc.name fileIO_test_write_async_018
+ * @tc.desc Test write() interfaces. Callback.
+ * Write with invalid length parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_async_018', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_write_async_018');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ const invalidLength = 9999;
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.write(file.fd, FILE_CONTENT, {
+ length: invalidLength,
+ }, (err) => {
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_write_async_018 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_1900
+ * @tc.name fileIO_test_write_async_019
+ * @tc.desc Test write() interfaces. Callback.
+ * Write with invalid length parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_async_019', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_write_async_019');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ const invalidLength = 4097;
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.write(file.fd, new ArrayBuffer(4096), {
+ length: invalidLength,
+ }, (err) => {
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_write_async_019 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_2000
+ * @tc.name fileIO_test_write_async_020
+ * @tc.desc Test write() interfaces. Callback.
+ * Write with invalid length parameters.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_async_020', 0, async function (done) {
+ let fpath = await nextFileName('fileIO_test_write_async_020');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.WRITE_ONLY);
+ const invalidOffset = -1;
+
+ try {
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.write(file.fd, FILE_CONTENT, {
+ offset: invalidOffset,
+ }, (err) => {
+ expect(false).assertTrue();
+ });
+ } catch (e) {
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ console.log('fileIO_test_write_async_020 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == 'Invalid argument').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_2100
+ * @tc.name fileIO_test_write_async_021
+ * @tc.desc Test write() interfaces. Promise.
+ * Undefined option arguments, use default options.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_async_021', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_test_write_async_021');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ let bytesWritten1 = await fileIO.write(file.fd, FILE_CONTENT, undefined);
+ expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
+ let bytesWritten2 = await fileIO.write(file.fd, new ArrayBuffer(FILE_CONTENT.length), undefined);
+ expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), { offset: 0 });
+ expect(readLen == FILE_CONTENT.length * 2).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_write_async_021 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_2200
+ * @tc.name fileIO_test_write_async_022
+ * @tc.desc Test write() interfaces. Callback.
+ * Undefined option arguments, use default options.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_async_022', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_test_write_async_022');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.write(file.fd, FILE_CONTENT, undefined, (err, bytesWritten1) => {
+ if (err) {
+ console.log('fileIO_test_write_async_022 err package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
+ fileIO.write(file.fd, new ArrayBuffer(FILE_CONTENT.length), undefined, (err, bytesWritten2) => {
+ if (err) {
+ console.log('fileIO_test_write_async_022 err package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), { offset: 0 });
+ expect(readLen == FILE_CONTENT.length * 2).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ });
+ } catch (e) {
+ console.log('fileIO_test_write_async_022 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_2300
+ * @tc.name fileIO_test_write_async_023
+ * @tc.desc Test write() interfaces. Promise.
+ * Undefined option arguments, use default options.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_async_023', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_test_write_async_023');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ let bytesWritten1 = await fileIO.write(file.fd, FILE_CONTENT, {
+ length: undefined,
+ offset: undefined,
+ encoding: undefined,
+ });
+ expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
+ let bytesWritten2 = await fileIO.write(file.fd, new ArrayBuffer(FILE_CONTENT.length), {
+ length: undefined,
+ offset: undefined,
+ encoding: undefined,
+ });
+ expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), { offset: 0 });
+ expect(readLen == FILE_CONTENT.length * 2).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ } catch (e) {
+ console.log('fileIO_test_write_async_023 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_FILEIO_WRITE_ASYNC_2400
+ * @tc.name fileIO_test_write_async_024
+ * @tc.desc Test write() interfaces. Callback.
+ * Undefined option arguments, use default options.
+ * @tc.size MEDIUM
+ * @tc.type Functoin
+ * @tc.level Level 3
+ * @tc.require
+ */
+ it('fileIO_test_write_async_024', 3, async function (done) {
+ let fpath = await nextFileName('fileIO_test_write_async_024');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+
+ try {
+ let file = fileIO.openSync(fpath, fileIO.OpenMode.READ_WRITE);
+ expect(isIntNum(file.fd)).assertTrue();
+ fileIO.write(file.fd, FILE_CONTENT, {
+ length: undefined,
+ offset: undefined,
+ encoding: undefined,
+ }, (err, bytesWritten1) => {
+ if (err) {
+ console.log('fileIO_test_write_async_011 err package1: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(bytesWritten1 == FILE_CONTENT.length).assertTrue();
+ fileIO.write(file.fd, new ArrayBuffer(FILE_CONTENT.length), {
+ length: undefined,
+ offset: undefined,
+ encoding: undefined,
+ }, (err, bytesWritten2) => {
+ if (err) {
+ console.log('fileIO_test_write_async_005 err package2: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ expect(bytesWritten2 == FILE_CONTENT.length).assertTrue();
+ let readLen = fileIO.readSync(file.fd, new ArrayBuffer(4096), { offset: 0 });
+ expect(readLen == FILE_CONTENT.length * 2).assertTrue();
+ fileIO.closeSync(file);
+ fileIO.unlinkSync(fpath);
+ done();
+ });
+ });
+ } catch (e) {
+ console.log('fileIO_test_write_async_024 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+})
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/resources/base/element/string.json b/storage/storagefileiov9jstest/src/main/resources/base/element/string.json
similarity index 94%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/resources/base/element/string.json
rename to storage/storagefileiov9jstest/src/main/resources/base/element/string.json
index 3f9ba4d59ec455e0d468a529ede22b8c6aab5ed9..ce37a9309f48bf729150ad091ab4f0e8863a8652 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/resources/base/element/string.json
+++ b/storage/storagefileiov9jstest/src/main/resources/base/element/string.json
@@ -1,28 +1,28 @@
-{
- "string": [
- {
- "name": "app_name",
- "value": "storagefilefsjstest"
- },
- {
- "name": "mainability_description",
- "value": "JS_Phone_Empty Feature Ability"
- },
- {
- "name": "MainAbility_desc",
- "value": "description"
- },
- {
- "name": "MainAbility_label",
- "value": "label"
- },
- {
- "name": "TestAbility_desc",
- "value": "description"
- },
- {
- "name": "TestAbility_label",
- "value": "label"
- }
- ]
-}
+{
+ "string": [
+ {
+ "name": "app_name",
+ "value": "storagefilefsjstest"
+ },
+ {
+ "name": "mainability_description",
+ "value": "JS_Phone_Empty Feature Ability"
+ },
+ {
+ "name": "MainAbility_desc",
+ "value": "description"
+ },
+ {
+ "name": "MainAbility_label",
+ "value": "label"
+ },
+ {
+ "name": "TestAbility_desc",
+ "value": "description"
+ },
+ {
+ "name": "TestAbility_label",
+ "value": "label"
+ }
+ ]
+}
diff --git a/storage/storagefileiov9jstest/entry/src/main/resources/base/media/icon.png b/storage/storagefileiov9jstest/src/main/resources/base/media/icon.png
similarity index 100%
rename from storage/storagefileiov9jstest/entry/src/main/resources/base/media/icon.png
rename to storage/storagefileiov9jstest/src/main/resources/base/media/icon.png
diff --git a/storage/storagefilejstest/BUILD.gn b/storage/storagefilejstest/BUILD.gn
index f4f68a7f6cf9cf6d44c37422ab7e8b32049878cb..253ddbe5aff7efddc7f8dbe7a6c1849365ff8da1 100644
--- a/storage/storagefilejstest/BUILD.gn
+++ b/storage/storagefilejstest/BUILD.gn
@@ -1,4 +1,4 @@
-# Copyright (c) 2023 Huawei Device Co., Ltd.
+# Copyright (C) 2021 Huawei Device Co., Ltd.
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
@@ -13,11 +13,23 @@
import("//test/xts/tools/build/suite.gni")
-ohos_js_app_suite("storagefile_js_test") {
- test_hap = true
- testonly = true
+ohos_js_hap_suite("storagefile_js_test") {
+ hap_profile = "./src/main/config.json"
+ deps = [
+ ":storagefile_js_assets",
+ ":storagefile_js_resources",
+ ]
+ certificate_profile = "./signature/openharmony_sx.p7b"
hap_name = "ActsStorageFileJSTest"
subsystem_name = "filemanagement"
part_name = "file_api"
- certificate_profile = "./signature/openharmony_sx.p7b"
+}
+ohos_js_assets("storagefile_js_assets") {
+ js2abc = true
+ hap_profile = "./src/main/config.json"
+ source_dir = "./src/main/js"
+}
+ohos_resources("storagefile_js_resources") {
+ sources = [ "./src/main/resources" ]
+ hap_profile = "./src/main/config.json"
}
diff --git a/storage/storagefilejstest/Test.json b/storage/storagefilejstest/Test.json
index a06d8bdf7ce674d10a1f920f90109b39ccb5d15b..5d01ba638110f426b203d61a1b825fe86a784569 100644
--- a/storage/storagefilejstest/Test.json
+++ b/storage/storagefilejstest/Test.json
@@ -1,17 +1,17 @@
-{
- "description": "Configuration for storage file Tests",
- "driver": {
- "type": "OHJSUnitTest",
- "test-timeout": "120000",
- "shell-timeout": "120000",
- "bundle-name": "ohos.acts.storage.file",
- "package-name": "ohos.acts.storage.file_test"
- },
- "kits": [
- {
- "test-file-name": ["ActsStorageFileJSTest.hap"],
- "type": "AppInstallKit",
- "cleanup-apps": true
- }
- ]
+{
+ "description": "Configuration for storage file Tests",
+ "driver": {
+ "type": "OHJSUnitTest",
+ "test-timeout": "120000",
+ "shell-timeout": "120000",
+ "bundle-name": "ohos.acts.storage.file",
+ "package-name": "ohos.acts.storage.file"
+ },
+ "kits": [
+ {
+ "test-file-name": ["ActsStorageFileJSTest.hap"],
+ "type": "AppInstallKit",
+ "cleanup-apps": true
+ }
+ ]
}
\ No newline at end of file
diff --git a/storage/storagefilejstest/build-profile.json5 b/storage/storagefilejstest/build-profile.json5
deleted file mode 100644
index 7715cddc0112e0e0c8e40623b77ff67b82731829..0000000000000000000000000000000000000000
--- a/storage/storagefilejstest/build-profile.json5
+++ /dev/null
@@ -1,42 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-{
- "app": {
- "signingConfigs": [
- ],
- "compileSdkVersion": 10,
- "compatibleSdkVersion": 10,
- "products": [
- {
- "name": "default",
- "signingConfig": "default"
- }
- ]
- },
- "modules": [
- {
- "name": "entry",
- "srcPath": "./entry",
- "targets": [
- {
- "name": "default",
- "applyToProducts": [
- "default"
- ]
- }
- ]
- }
- ]
-}
\ No newline at end of file
diff --git a/storage/storagefilejstest/entry/build-profile.json5 b/storage/storagefilejstest/entry/build-profile.json5
deleted file mode 100644
index a6a17e6971173aacea7b75d9ae897a80d335dc0b..0000000000000000000000000000000000000000
--- a/storage/storagefilejstest/entry/build-profile.json5
+++ /dev/null
@@ -1,27 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-{
- "apiType": 'faMode',
- "buildOption": {
- },
- "targets": [
- {
- "name": "default",
- },
- {
- "name": "ohosTest",
- }
- ]
-}
\ No newline at end of file
diff --git a/storage/storagefilejstest/entry/hvigorfile.ts b/storage/storagefilejstest/entry/hvigorfile.ts
deleted file mode 100644
index 89d831db3f5a6431ef4f9078128ad61b6ae36c48..0000000000000000000000000000000000000000
--- a/storage/storagefilejstest/entry/hvigorfile.ts
+++ /dev/null
@@ -1,16 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-// Script for compiling build behavior. It is built in the build plug-in and cannot be modified currently.
-export { legacyHapTasks } from '@ohos/hvigor-ohos-plugin';
diff --git a/storage/storagefilejstest/entry/oh-package.json5 b/storage/storagefilejstest/entry/oh-package.json5
deleted file mode 100644
index 75ca1d70feb1c490379299fe342058a2a7183388..0000000000000000000000000000000000000000
--- a/storage/storagefilejstest/entry/oh-package.json5
+++ /dev/null
@@ -1,24 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-{
- "license": "",
- "devDependencies": {},
- "author": "",
- "name": "entry",
- "description": "Please describe the basic information.",
- "main": "",
- "version": "1.0.0",
- "dependencies": {}
-}
diff --git a/storage/storagefilejstest/entry/src/main/config.json b/storage/storagefilejstest/entry/src/main/config.json
deleted file mode 100644
index 2699a7adb499d75d8b2a67db9901212f50174221..0000000000000000000000000000000000000000
--- a/storage/storagefilejstest/entry/src/main/config.json
+++ /dev/null
@@ -1,65 +0,0 @@
-{
- "app":{
- "bundleName":"ohos.acts.storage.file",
- "vendor":"example",
- "version":{
- "code":1000000,
- "name":"1.0.0"
- }
- },
- "deviceConfig":{
-
- },
- "module":{
- "package":"ohos.acts.storage.file",
- "name":".entry",
- "mainAbility":".MainAbility",
- "deviceType": [
- "tablet",
- "default"
- ],
- "distro":{
- "deliveryWithInstall":true,
- "installationFree":true,
- "moduleName":"entry",
- "moduleType":"entry"
- },
- "abilities":[
- {
- "description":"$string:MainAbility_desc",
- "formsEnabled":false,
- "icon":"$media:icon",
- "label":"$string:MainAbility_label",
- "launchType":"standard",
- "name":".MainAbility",
- "orientation":"unspecified",
- "skills":[
- {
- "actions":[
- "action.system.home"
- ],
- "entities":[
- "entity.system.home"
- ]
- }
- ],
- "srcLanguage":"js",
- "srcPath":"MainAbility",
- "type":"page",
- "visible":true
- }
- ],
- "js":[
- {
- "name":".MainAbility",
- "pages":[
- "pages/index/index"
- ],
- "window":{
- "autoDesignWidth":false,
- "designWidth":720
- }
- }
- ]
- }
-}
\ No newline at end of file
diff --git a/storage/storagefilejstest/entry/src/main/js/MainAbility/app.js b/storage/storagefilejstest/entry/src/main/js/MainAbility/app.js
deleted file mode 100644
index 8c9a4fce93b5e76779bdf446c49269a5a51db98a..0000000000000000000000000000000000000000
--- a/storage/storagefilejstest/entry/src/main/js/MainAbility/app.js
+++ /dev/null
@@ -1,26 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-import hilog from '@ohos.hilog';
-export default {
- onCreate() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'Application onCreate');
- },
- onDestroy() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'Application onDestroy');
- },
-}
-
-
-
diff --git a/storage/storagefilejstest/entry/src/main/js/MainAbility/pages/index/index.css b/storage/storagefilejstest/entry/src/main/js/MainAbility/pages/index/index.css
deleted file mode 100644
index a711febae0b34889547cd72fbe5f8cc3e0bd043c..0000000000000000000000000000000000000000
--- a/storage/storagefilejstest/entry/src/main/js/MainAbility/pages/index/index.css
+++ /dev/null
@@ -1,60 +0,0 @@
-/*
- * Copyright (c) 2022 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-.container {
- flex-direction: column;
- justify-content: center;
- align-items: center;
- width: 100%;
- height: 100%;
-}
-
-.title {
- font-size: 40px;
- color: #000000;
- opacity: 0.9;
-}
-
-@media screen and (device-type: tablet) and (orientation: landscape) {
- .title {
- font-size: 100px;
- }
-}
-
-@media screen and (device-type: wearable) {
- .title {
- font-size: 28px;
- color: #FFFFFF;
- }
-}
-
-@media screen and (device-type: tv) {
- .container {
- background-image: url("/common/images/Wallpaper.png");
- background-size: cover;
- background-repeat: no-repeat;
- background-position: center;
- }
-
- .title {
- font-size: 100px;
- color: #FFFFFF;
- }
-}
-
-@media screen and (device-type: phone) and (orientation: landscape) {
- .title {
- font-size: 60px;
- }
-}
diff --git a/storage/storagefilejstest/entry/src/main/js/MainAbility/pages/index/index.hml b/storage/storagefilejstest/entry/src/main/js/MainAbility/pages/index/index.hml
deleted file mode 100644
index 95bd1e877b3fa9f5f4e4dc0ff608591b540d116d..0000000000000000000000000000000000000000
--- a/storage/storagefilejstest/entry/src/main/js/MainAbility/pages/index/index.hml
+++ /dev/null
@@ -1,19 +0,0 @@
-/*
- * Copyright (c) 2022 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-
- {{ $t('strings.hello') }} {{ title }}
-
-
diff --git a/storage/storagefilejstest/entry/src/main/js/MainAbility/pages/index/index.js b/storage/storagefilejstest/entry/src/main/js/MainAbility/pages/index/index.js
deleted file mode 100644
index f086298302bd6362b079bf99cf40dfa1e00d85e9..0000000000000000000000000000000000000000
--- a/storage/storagefilejstest/entry/src/main/js/MainAbility/pages/index/index.js
+++ /dev/null
@@ -1,22 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-export default {
- data: {
- title: ""
- },
- onInit() {
- this.title = this.$t('strings.world');
- }
-}
diff --git a/storage/storagefilejstest/entry/src/ohosTest/config.json b/storage/storagefilejstest/entry/src/ohosTest/config.json
deleted file mode 100644
index 9cc46c01df0084036bba95695fe022e64f6dbd24..0000000000000000000000000000000000000000
--- a/storage/storagefilejstest/entry/src/ohosTest/config.json
+++ /dev/null
@@ -1,69 +0,0 @@
-{
- "app":{
- "bundleName":"ohos.acts.storage.file",
- "vendor":"example",
- "version":{
- "code":1000000,
- "name":"1.0.0"
- }
- },
- "deviceConfig":{
-
- },
- "module":{
- "package":"ohos.acts.storage.file_test",
- "name":".entry_test",
- "mainAbility":".TestAbility",
- "deviceType": [
- "tablet",
- "default"
- ],
- "testRunner":{
- "name":"OpenHarmonyTestRunner",
- "srcPath":"TestRunner"
- },
- "distro":{
- "deliveryWithInstall":true,
- "installationFree":true,
- "moduleName":"entry_test",
- "moduleType":"feature"
- },
- "abilities":[
- {
- "description":"$string:TestAbility_desc",
- "formsEnabled":false,
- "icon":"$media:icon",
- "label":"$string:TestAbility_label",
- "launchType":"standard",
- "name":".TestAbility",
- "orientation":"unspecified",
- "skills":[
- {
- "actions":[
- "action.system.home"
- ],
- "entities":[
- "entity.system.home"
- ]
- }
- ],
- "srcLanguage":"js",
- "srcPath":"TestAbility",
- "type":"page",
- "visible":true
- }
- ],
- "js":[
- {
- "name":".TestAbility",
- "pages":[
- "pages/index/index"
- ],
- "window":{
- "autoDesignWidth":false,
- "designWidth":720
- }
- }
- ]
- }
-}
\ No newline at end of file
diff --git a/storage/storagefilejstest/entry/src/ohosTest/resources/base/element/string.json b/storage/storagefilejstest/entry/src/ohosTest/resources/base/element/string.json
deleted file mode 100644
index 1357196cbc6930c538004615c72b82b07441afe4..0000000000000000000000000000000000000000
--- a/storage/storagefilejstest/entry/src/ohosTest/resources/base/element/string.json
+++ /dev/null
@@ -1,28 +0,0 @@
-{
- "string": [
- {
- "name": "app_name",
- "value": "storagefilejstest"
- },
- {
- "name": "mainability_description",
- "value": "JS_Phone_Empty Feature Ability"
- },
- {
- "name": "MainAbility_desc",
- "value": "description"
- },
- {
- "name": "MainAbility_label",
- "value": "label"
- },
- {
- "name": "TestAbility_desc",
- "value": "description"
- },
- {
- "name": "TestAbility_label",
- "value": "label"
- }
- ]
-}
diff --git a/storage/storagefilejstest/hvigor/hvigor-config.json5 b/storage/storagefilejstest/hvigor/hvigor-config.json5
deleted file mode 100644
index d1ed6c3c0cb895265a376515209a0575aeb7d898..0000000000000000000000000000000000000000
--- a/storage/storagefilejstest/hvigor/hvigor-config.json5
+++ /dev/null
@@ -1,20 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-{
- "hvigorVersion": "2.0.0",
- "dependencies": {
- "@ohos/hvigor-ohos-plugin": "2.0.0"
- }
-}
diff --git a/storage/storagefilejstest/hvigor/hvigor-wrapper.js b/storage/storagefilejstest/hvigor/hvigor-wrapper.js
deleted file mode 100644
index 2507619ca768432ff3fb806441f29eff47a4c4f0..0000000000000000000000000000000000000000
--- a/storage/storagefilejstest/hvigor/hvigor-wrapper.js
+++ /dev/null
@@ -1,16 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-"use strict";var e=require("fs"),t=require("path"),n=require("os"),r=require("crypto"),u=require("child_process"),o=require("constants"),i=require("stream"),s=require("util"),c=require("assert"),a=require("tty"),l=require("zlib"),f=require("net");function d(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var D=d(e),p=d(t),E=d(n),m=d(r),h=d(u),y=d(o),C=d(i),F=d(s),g=d(c),A=d(a),v=d(l),S=d(f),w="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{},O={},b={},_={},B=w&&w.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(_,"__esModule",{value:!0}),_.isMac=_.isLinux=_.isWindows=void 0;const P=B(E.default),k="Windows_NT",x="Linux",N="Darwin";_.isWindows=function(){return P.default.type()===k},_.isLinux=function(){return P.default.type()===x},_.isMac=function(){return P.default.type()===N};var I={},T=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),R=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),M=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)"default"!==n&&Object.prototype.hasOwnProperty.call(e,n)&&T(t,e,n);return R(t,e),t};Object.defineProperty(I,"__esModule",{value:!0}),I.hash=void 0;const L=M(m.default);I.hash=function(e,t="md5"){return L.createHash(t).update(e,"utf-8").digest("hex")},function(e){var t=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),n=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),r=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var r={};if(null!=e)for(var u in e)"default"!==u&&Object.prototype.hasOwnProperty.call(e,u)&&t(r,e,u);return n(r,e),r};Object.defineProperty(e,"__esModule",{value:!0}),e.HVIGOR_BOOT_JS_FILE_PATH=e.HVIGOR_PROJECT_DEPENDENCY_PACKAGE_JSON_PATH=e.HVIGOR_PROJECT_DEPENDENCIES_HOME=e.HVIGOR_PROJECT_WRAPPER_HOME=e.HVIGOR_PROJECT_NAME=e.HVIGOR_PROJECT_ROOT_DIR=e.HVIGOR_PROJECT_CACHES_HOME=e.HVIGOR_PNPM_STORE_PATH=e.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH=e.HVIGOR_WRAPPER_TOOLS_HOME=e.HVIGOR_USER_HOME=e.DEFAULT_PACKAGE_JSON=e.DEFAULT_HVIGOR_CONFIG_JSON_FILE_NAME=e.PNPM=e.HVIGOR=e.NPM_TOOL=e.PNPM_TOOL=e.HVIGOR_ENGINE_PACKAGE_NAME=void 0;const u=r(p.default),o=r(E.default),i=_,s=I;e.HVIGOR_ENGINE_PACKAGE_NAME="@ohos/hvigor",e.PNPM_TOOL=(0,i.isWindows)()?"pnpm.cmd":"pnpm",e.NPM_TOOL=(0,i.isWindows)()?"npm.cmd":"npm",e.HVIGOR="hvigor",e.PNPM="pnpm",e.DEFAULT_HVIGOR_CONFIG_JSON_FILE_NAME="hvigor-config.json5",e.DEFAULT_PACKAGE_JSON="package.json",e.HVIGOR_USER_HOME=u.resolve(o.homedir(),".hvigor"),e.HVIGOR_WRAPPER_TOOLS_HOME=u.resolve(e.HVIGOR_USER_HOME,"wrapper","tools"),e.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH=u.resolve(e.HVIGOR_WRAPPER_TOOLS_HOME,"node_modules",".bin",e.PNPM_TOOL),e.HVIGOR_PNPM_STORE_PATH=u.resolve(e.HVIGOR_USER_HOME,"caches"),e.HVIGOR_PROJECT_CACHES_HOME=u.resolve(e.HVIGOR_USER_HOME,"project_caches"),e.HVIGOR_PROJECT_ROOT_DIR=process.cwd(),e.HVIGOR_PROJECT_NAME=u.basename((0,s.hash)(e.HVIGOR_PROJECT_ROOT_DIR)),e.HVIGOR_PROJECT_WRAPPER_HOME=u.resolve(e.HVIGOR_PROJECT_ROOT_DIR,e.HVIGOR),e.HVIGOR_PROJECT_DEPENDENCIES_HOME=u.resolve(e.HVIGOR_PROJECT_CACHES_HOME,e.HVIGOR_PROJECT_NAME,"workspace"),e.HVIGOR_PROJECT_DEPENDENCY_PACKAGE_JSON_PATH=u.resolve(e.HVIGOR_PROJECT_DEPENDENCIES_HOME,e.DEFAULT_PACKAGE_JSON),e.HVIGOR_BOOT_JS_FILE_PATH=u.resolve(e.HVIGOR_PROJECT_DEPENDENCIES_HOME,"node_modules","@ohos","hvigor","bin","hvigor.js")}(b);var j={},$={};Object.defineProperty($,"__esModule",{value:!0}),$.logInfoPrintConsole=$.logErrorAndExit=void 0,$.logErrorAndExit=function(e){e instanceof Error?console.error(e.message):console.error(e),process.exit(-1)},$.logInfoPrintConsole=function(e){console.log(e)};var H=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),J=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),G=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)"default"!==n&&Object.prototype.hasOwnProperty.call(e,n)&&H(t,e,n);return J(t,e),t},V=w&&w.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(j,"__esModule",{value:!0}),j.isFileExists=j.offlinePluginConversion=j.executeCommand=j.getNpmPath=j.hasNpmPackInPaths=void 0;const U=h.default,W=G(p.default),z=b,K=$,q=V(D.default);j.hasNpmPackInPaths=function(e,t){try{return require.resolve(e,{paths:[...t]}),!0}catch(e){return!1}},j.getNpmPath=function(){const e=process.execPath;return W.join(W.dirname(e),z.NPM_TOOL)},j.executeCommand=function(e,t,n){0!==(0,U.spawnSync)(e,t,n).status&&(0,K.logErrorAndExit)(`Error: ${e} ${t} execute failed.See above for details.`)},j.offlinePluginConversion=function(e,t){return t.startsWith("file:")||t.endsWith(".tgz")?W.resolve(e,z.HVIGOR,t.replace("file:","")):t},j.isFileExists=function(e){return q.default.existsSync(e)&&q.default.statSync(e).isFile()},function(e){var t=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),n=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),r=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var r={};if(null!=e)for(var u in e)"default"!==u&&Object.prototype.hasOwnProperty.call(e,u)&&t(r,e,u);return n(r,e),r},u=w&&w.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(e,"__esModule",{value:!0}),e.executeInstallPnpm=e.isPnpmAvailable=e.environmentHandler=e.checkNpmConifg=e.PNPM_VERSION=void 0;const o=r(D.default),i=b,s=j,c=r(p.default),a=$,l=h.default,f=u(E.default);e.PNPM_VERSION="7.30.0",e.checkNpmConifg=function(){const e=c.resolve(i.HVIGOR_PROJECT_ROOT_DIR,".npmrc"),t=c.resolve(f.default.homedir(),".npmrc");if((0,s.isFileExists)(e)||(0,s.isFileExists)(t))return;const n=(0,s.getNpmPath)(),r=(0,l.spawnSync)(n,["config","get","prefix"],{cwd:i.HVIGOR_PROJECT_ROOT_DIR});if(0!==r.status||!r.stdout)return void(0,a.logErrorAndExit)("Error: The hvigor depends on the npmrc file. Configure the npmrc file first.");const u=c.resolve(`${r.stdout}`.replace(/[\r\n]/gi,""),".npmrc");(0,s.isFileExists)(u)||(0,a.logErrorAndExit)("Error: The hvigor depends on the npmrc file. Configure the npmrc file first.")},e.environmentHandler=function(){process.env["npm_config_update-notifier"]="false"},e.isPnpmAvailable=function(){return!!o.existsSync(i.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH)&&(0,s.hasNpmPackInPaths)("pnpm",[i.HVIGOR_WRAPPER_TOOLS_HOME])},e.executeInstallPnpm=function(){(0,a.logInfoPrintConsole)(`Installing pnpm@${e.PNPM_VERSION}...`);const t=(0,s.getNpmPath)();!function(){const t=c.resolve(i.HVIGOR_WRAPPER_TOOLS_HOME,i.DEFAULT_PACKAGE_JSON);try{o.existsSync(i.HVIGOR_WRAPPER_TOOLS_HOME)||o.mkdirSync(i.HVIGOR_WRAPPER_TOOLS_HOME,{recursive:!0});const n={dependencies:{}};n.dependencies[i.PNPM]=e.PNPM_VERSION,o.writeFileSync(t,JSON.stringify(n))}catch(e){(0,a.logErrorAndExit)(`Error: EPERM: operation not permitted,create ${t} failed.`)}}(),(0,s.executeCommand)(t,["install","pnpm"],{cwd:i.HVIGOR_WRAPPER_TOOLS_HOME,stdio:["inherit","inherit","inherit"],env:process.env}),(0,a.logInfoPrintConsole)("Pnpm install success.")}}(O);var Y={},X={},Z={},Q={};Object.defineProperty(Q,"__esModule",{value:!0}),Q.Unicode=void 0;class ee{}Q.Unicode=ee,ee.Space_Separator=/[\u1680\u2000-\u200A\u202F\u205F\u3000]/,ee.ID_Start=/[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u05D0-\u05EA\u05F0-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u0860-\u086A\u08A0-\u08B4\u08B6-\u08BD\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u09FC\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0AF9\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58-\u0C5A\u0C60\u0C61\u0C80\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D54-\u0D56\u0D5F-\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1711\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1877\u1880-\u1884\u1887-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1C80-\u1C88\u1CE9-\u1CEC\u1CEE-\u1CF1\u1CF5\u1CF6\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005-\u3007\u3021-\u3029\u3031-\u3035\u3038-\u303C\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312E\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FEA\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6EF\uA717-\uA71F\uA722-\uA788\uA78B-\uA7AE\uA7B0-\uA7B7\uA7F7-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA8FD\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uA9E0-\uA9E4\uA9E6-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB65\uAB70-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD40-\uDD74\uDE80-\uDE9C\uDEA0-\uDED0\uDF00-\uDF1F\uDF2D-\uDF4A\uDF50-\uDF75\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDCB0-\uDCD3\uDCD8-\uDCFB\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDCE0-\uDCF2\uDCF4\uDCF5\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00\uDE10-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE4\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48\uDC80-\uDCB2\uDCC0-\uDCF2]|\uD804[\uDC03-\uDC37\uDC83-\uDCAF\uDCD0-\uDCE8\uDD03-\uDD26\uDD50-\uDD72\uDD76\uDD83-\uDDB2\uDDC1-\uDDC4\uDDDA\uDDDC\uDE00-\uDE11\uDE13-\uDE2B\uDE80-\uDE86\uDE88\uDE8A-\uDE8D\uDE8F-\uDE9D\uDE9F-\uDEA8\uDEB0-\uDEDE\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3D\uDF50\uDF5D-\uDF61]|\uD805[\uDC00-\uDC34\uDC47-\uDC4A\uDC80-\uDCAF\uDCC4\uDCC5\uDCC7\uDD80-\uDDAE\uDDD8-\uDDDB\uDE00-\uDE2F\uDE44\uDE80-\uDEAA\uDF00-\uDF19]|\uD806[\uDCA0-\uDCDF\uDCFF\uDE00\uDE0B-\uDE32\uDE3A\uDE50\uDE5C-\uDE83\uDE86-\uDE89\uDEC0-\uDEF8]|\uD807[\uDC00-\uDC08\uDC0A-\uDC2E\uDC40\uDC72-\uDC8F\uDD00-\uDD06\uDD08\uDD09\uDD0B-\uDD30\uDD46]|\uD808[\uDC00-\uDF99]|\uD809[\uDC00-\uDC6E\uDC80-\uDD43]|[\uD80C\uD81C-\uD820\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD811[\uDC00-\uDE46]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDED0-\uDEED\uDF00-\uDF2F\uDF40-\uDF43\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50\uDF93-\uDF9F\uDFE0\uDFE1]|\uD821[\uDC00-\uDFEC]|\uD822[\uDC00-\uDEF2]|\uD82C[\uDC00-\uDD1E\uDD70-\uDEFB]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB]|\uD83A[\uDC00-\uDCC4\uDD00-\uDD43]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0]|\uD87E[\uDC00-\uDE1D]/,ee.ID_Continue=/[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0300-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u0483-\u0487\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u0591-\u05BD\u05BF\u05C1\u05C2\u05C4\u05C5\u05C7\u05D0-\u05EA\u05F0-\u05F2\u0610-\u061A\u0620-\u0669\u066E-\u06D3\u06D5-\u06DC\u06DF-\u06E8\u06EA-\u06FC\u06FF\u0710-\u074A\u074D-\u07B1\u07C0-\u07F5\u07FA\u0800-\u082D\u0840-\u085B\u0860-\u086A\u08A0-\u08B4\u08B6-\u08BD\u08D4-\u08E1\u08E3-\u0963\u0966-\u096F\u0971-\u0983\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BC-\u09C4\u09C7\u09C8\u09CB-\u09CE\u09D7\u09DC\u09DD\u09DF-\u09E3\u09E6-\u09F1\u09FC\u0A01-\u0A03\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A3C\u0A3E-\u0A42\u0A47\u0A48\u0A4B-\u0A4D\u0A51\u0A59-\u0A5C\u0A5E\u0A66-\u0A75\u0A81-\u0A83\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABC-\u0AC5\u0AC7-\u0AC9\u0ACB-\u0ACD\u0AD0\u0AE0-\u0AE3\u0AE6-\u0AEF\u0AF9-\u0AFF\u0B01-\u0B03\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3C-\u0B44\u0B47\u0B48\u0B4B-\u0B4D\u0B56\u0B57\u0B5C\u0B5D\u0B5F-\u0B63\u0B66-\u0B6F\u0B71\u0B82\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BBE-\u0BC2\u0BC6-\u0BC8\u0BCA-\u0BCD\u0BD0\u0BD7\u0BE6-\u0BEF\u0C00-\u0C03\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D-\u0C44\u0C46-\u0C48\u0C4A-\u0C4D\u0C55\u0C56\u0C58-\u0C5A\u0C60-\u0C63\u0C66-\u0C6F\u0C80-\u0C83\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBC-\u0CC4\u0CC6-\u0CC8\u0CCA-\u0CCD\u0CD5\u0CD6\u0CDE\u0CE0-\u0CE3\u0CE6-\u0CEF\u0CF1\u0CF2\u0D00-\u0D03\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D44\u0D46-\u0D48\u0D4A-\u0D4E\u0D54-\u0D57\u0D5F-\u0D63\u0D66-\u0D6F\u0D7A-\u0D7F\u0D82\u0D83\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0DCA\u0DCF-\u0DD4\u0DD6\u0DD8-\u0DDF\u0DE6-\u0DEF\u0DF2\u0DF3\u0E01-\u0E3A\u0E40-\u0E4E\u0E50-\u0E59\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB9\u0EBB-\u0EBD\u0EC0-\u0EC4\u0EC6\u0EC8-\u0ECD\u0ED0-\u0ED9\u0EDC-\u0EDF\u0F00\u0F18\u0F19\u0F20-\u0F29\u0F35\u0F37\u0F39\u0F3E-\u0F47\u0F49-\u0F6C\u0F71-\u0F84\u0F86-\u0F97\u0F99-\u0FBC\u0FC6\u1000-\u1049\u1050-\u109D\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u135D-\u135F\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1714\u1720-\u1734\u1740-\u1753\u1760-\u176C\u176E-\u1770\u1772\u1773\u1780-\u17D3\u17D7\u17DC\u17DD\u17E0-\u17E9\u180B-\u180D\u1810-\u1819\u1820-\u1877\u1880-\u18AA\u18B0-\u18F5\u1900-\u191E\u1920-\u192B\u1930-\u193B\u1946-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u19D0-\u19D9\u1A00-\u1A1B\u1A20-\u1A5E\u1A60-\u1A7C\u1A7F-\u1A89\u1A90-\u1A99\u1AA7\u1AB0-\u1ABD\u1B00-\u1B4B\u1B50-\u1B59\u1B6B-\u1B73\u1B80-\u1BF3\u1C00-\u1C37\u1C40-\u1C49\u1C4D-\u1C7D\u1C80-\u1C88\u1CD0-\u1CD2\u1CD4-\u1CF9\u1D00-\u1DF9\u1DFB-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u203F\u2040\u2054\u2071\u207F\u2090-\u209C\u20D0-\u20DC\u20E1\u20E5-\u20F0\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D7F-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2DE0-\u2DFF\u2E2F\u3005-\u3007\u3021-\u302F\u3031-\u3035\u3038-\u303C\u3041-\u3096\u3099\u309A\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312E\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FEA\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA62B\uA640-\uA66F\uA674-\uA67D\uA67F-\uA6F1\uA717-\uA71F\uA722-\uA788\uA78B-\uA7AE\uA7B0-\uA7B7\uA7F7-\uA827\uA840-\uA873\uA880-\uA8C5\uA8D0-\uA8D9\uA8E0-\uA8F7\uA8FB\uA8FD\uA900-\uA92D\uA930-\uA953\uA960-\uA97C\uA980-\uA9C0\uA9CF-\uA9D9\uA9E0-\uA9FE\uAA00-\uAA36\uAA40-\uAA4D\uAA50-\uAA59\uAA60-\uAA76\uAA7A-\uAAC2\uAADB-\uAADD\uAAE0-\uAAEF\uAAF2-\uAAF6\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB65\uAB70-\uABEA\uABEC\uABED\uABF0-\uABF9\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE00-\uFE0F\uFE20-\uFE2F\uFE33\uFE34\uFE4D-\uFE4F\uFE70-\uFE74\uFE76-\uFEFC\uFF10-\uFF19\uFF21-\uFF3A\uFF3F\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD40-\uDD74\uDDFD\uDE80-\uDE9C\uDEA0-\uDED0\uDEE0\uDF00-\uDF1F\uDF2D-\uDF4A\uDF50-\uDF7A\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDCA0-\uDCA9\uDCB0-\uDCD3\uDCD8-\uDCFB\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDCE0-\uDCF2\uDCF4\uDCF5\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00-\uDE03\uDE05\uDE06\uDE0C-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE38-\uDE3A\uDE3F\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE6\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48\uDC80-\uDCB2\uDCC0-\uDCF2]|\uD804[\uDC00-\uDC46\uDC66-\uDC6F\uDC7F-\uDCBA\uDCD0-\uDCE8\uDCF0-\uDCF9\uDD00-\uDD34\uDD36-\uDD3F\uDD50-\uDD73\uDD76\uDD80-\uDDC4\uDDCA-\uDDCC\uDDD0-\uDDDA\uDDDC\uDE00-\uDE11\uDE13-\uDE37\uDE3E\uDE80-\uDE86\uDE88\uDE8A-\uDE8D\uDE8F-\uDE9D\uDE9F-\uDEA8\uDEB0-\uDEEA\uDEF0-\uDEF9\uDF00-\uDF03\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3C-\uDF44\uDF47\uDF48\uDF4B-\uDF4D\uDF50\uDF57\uDF5D-\uDF63\uDF66-\uDF6C\uDF70-\uDF74]|\uD805[\uDC00-\uDC4A\uDC50-\uDC59\uDC80-\uDCC5\uDCC7\uDCD0-\uDCD9\uDD80-\uDDB5\uDDB8-\uDDC0\uDDD8-\uDDDD\uDE00-\uDE40\uDE44\uDE50-\uDE59\uDE80-\uDEB7\uDEC0-\uDEC9\uDF00-\uDF19\uDF1D-\uDF2B\uDF30-\uDF39]|\uD806[\uDCA0-\uDCE9\uDCFF\uDE00-\uDE3E\uDE47\uDE50-\uDE83\uDE86-\uDE99\uDEC0-\uDEF8]|\uD807[\uDC00-\uDC08\uDC0A-\uDC36\uDC38-\uDC40\uDC50-\uDC59\uDC72-\uDC8F\uDC92-\uDCA7\uDCA9-\uDCB6\uDD00-\uDD06\uDD08\uDD09\uDD0B-\uDD36\uDD3A\uDD3C\uDD3D\uDD3F-\uDD47\uDD50-\uDD59]|\uD808[\uDC00-\uDF99]|\uD809[\uDC00-\uDC6E\uDC80-\uDD43]|[\uD80C\uD81C-\uD820\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD811[\uDC00-\uDE46]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDE60-\uDE69\uDED0-\uDEED\uDEF0-\uDEF4\uDF00-\uDF36\uDF40-\uDF43\uDF50-\uDF59\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50-\uDF7E\uDF8F-\uDF9F\uDFE0\uDFE1]|\uD821[\uDC00-\uDFEC]|\uD822[\uDC00-\uDEF2]|\uD82C[\uDC00-\uDD1E\uDD70-\uDEFB]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99\uDC9D\uDC9E]|\uD834[\uDD65-\uDD69\uDD6D-\uDD72\uDD7B-\uDD82\uDD85-\uDD8B\uDDAA-\uDDAD\uDE42-\uDE44]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB\uDFCE-\uDFFF]|\uD836[\uDE00-\uDE36\uDE3B-\uDE6C\uDE75\uDE84\uDE9B-\uDE9F\uDEA1-\uDEAF]|\uD838[\uDC00-\uDC06\uDC08-\uDC18\uDC1B-\uDC21\uDC23\uDC24\uDC26-\uDC2A]|\uD83A[\uDC00-\uDCC4\uDCD0-\uDCD6\uDD00-\uDD4A\uDD50-\uDD59]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0]|\uD87E[\uDC00-\uDE1D]|\uDB40[\uDD00-\uDDEF]/,Object.defineProperty(Z,"__esModule",{value:!0}),Z.JudgeUtil=void 0;const te=Q;Z.JudgeUtil=class{static isIgnoreChar(e){return"string"==typeof e&&("\t"===e||"\v"===e||"\f"===e||" "===e||" "===e||"\ufeff"===e||"\n"===e||"\r"===e||"\u2028"===e||"\u2029"===e)}static isSpaceSeparator(e){return"string"==typeof e&&te.Unicode.Space_Separator.test(e)}static isIdStartChar(e){return"string"==typeof e&&(e>="a"&&e<="z"||e>="A"&&e<="Z"||"$"===e||"_"===e||te.Unicode.ID_Start.test(e))}static isIdContinueChar(e){return"string"==typeof e&&(e>="a"&&e<="z"||e>="A"&&e<="Z"||e>="0"&&e<="9"||"$"===e||"_"===e||""===e||""===e||te.Unicode.ID_Continue.test(e))}static isDigitWithoutZero(e){return/[1-9]/.test(e)}static isDigit(e){return"string"==typeof e&&/[0-9]/.test(e)}static isHexDigit(e){return"string"==typeof e&&/[0-9A-Fa-f]/.test(e)}};var ne={},re={fromCallback:function(e){return Object.defineProperty((function(...t){if("function"!=typeof t[t.length-1])return new Promise(((n,r)=>{e.call(this,...t,((e,t)=>null!=e?r(e):n(t)))}));e.apply(this,t)}),"name",{value:e.name})},fromPromise:function(e){return Object.defineProperty((function(...t){const n=t[t.length-1];if("function"!=typeof n)return e.apply(this,t);e.apply(this,t.slice(0,-1)).then((e=>n(null,e)),n)}),"name",{value:e.name})}},ue=y.default,oe=process.cwd,ie=null,se=process.env.GRACEFUL_FS_PLATFORM||process.platform;process.cwd=function(){return ie||(ie=oe.call(process)),ie};try{process.cwd()}catch(e){}if("function"==typeof process.chdir){var ce=process.chdir;process.chdir=function(e){ie=null,ce.call(process,e)},Object.setPrototypeOf&&Object.setPrototypeOf(process.chdir,ce)}var ae=function(e){ue.hasOwnProperty("O_SYMLINK")&&process.version.match(/^v0\.6\.[0-2]|^v0\.5\./)&&function(e){e.lchmod=function(t,n,r){e.open(t,ue.O_WRONLY|ue.O_SYMLINK,n,(function(t,u){t?r&&r(t):e.fchmod(u,n,(function(t){e.close(u,(function(e){r&&r(t||e)}))}))}))},e.lchmodSync=function(t,n){var r,u=e.openSync(t,ue.O_WRONLY|ue.O_SYMLINK,n),o=!0;try{r=e.fchmodSync(u,n),o=!1}finally{if(o)try{e.closeSync(u)}catch(e){}else e.closeSync(u)}return r}}(e);e.lutimes||function(e){ue.hasOwnProperty("O_SYMLINK")&&e.futimes?(e.lutimes=function(t,n,r,u){e.open(t,ue.O_SYMLINK,(function(t,o){t?u&&u(t):e.futimes(o,n,r,(function(t){e.close(o,(function(e){u&&u(t||e)}))}))}))},e.lutimesSync=function(t,n,r){var u,o=e.openSync(t,ue.O_SYMLINK),i=!0;try{u=e.futimesSync(o,n,r),i=!1}finally{if(i)try{e.closeSync(o)}catch(e){}else e.closeSync(o)}return u}):e.futimes&&(e.lutimes=function(e,t,n,r){r&&process.nextTick(r)},e.lutimesSync=function(){})}(e);e.chown=r(e.chown),e.fchown=r(e.fchown),e.lchown=r(e.lchown),e.chmod=t(e.chmod),e.fchmod=t(e.fchmod),e.lchmod=t(e.lchmod),e.chownSync=u(e.chownSync),e.fchownSync=u(e.fchownSync),e.lchownSync=u(e.lchownSync),e.chmodSync=n(e.chmodSync),e.fchmodSync=n(e.fchmodSync),e.lchmodSync=n(e.lchmodSync),e.stat=o(e.stat),e.fstat=o(e.fstat),e.lstat=o(e.lstat),e.statSync=i(e.statSync),e.fstatSync=i(e.fstatSync),e.lstatSync=i(e.lstatSync),e.chmod&&!e.lchmod&&(e.lchmod=function(e,t,n){n&&process.nextTick(n)},e.lchmodSync=function(){});e.chown&&!e.lchown&&(e.lchown=function(e,t,n,r){r&&process.nextTick(r)},e.lchownSync=function(){});"win32"===se&&(e.rename="function"!=typeof e.rename?e.rename:function(t){function n(n,r,u){var o=Date.now(),i=0;t(n,r,(function s(c){if(c&&("EACCES"===c.code||"EPERM"===c.code||"EBUSY"===c.code)&&Date.now()-o<6e4)return setTimeout((function(){e.stat(r,(function(e,o){e&&"ENOENT"===e.code?t(n,r,s):u(c)}))}),i),void(i<100&&(i+=10));u&&u(c)}))}return Object.setPrototypeOf&&Object.setPrototypeOf(n,t),n}(e.rename));function t(t){return t?function(n,r,u){return t.call(e,n,r,(function(e){s(e)&&(e=null),u&&u.apply(this,arguments)}))}:t}function n(t){return t?function(n,r){try{return t.call(e,n,r)}catch(e){if(!s(e))throw e}}:t}function r(t){return t?function(n,r,u,o){return t.call(e,n,r,u,(function(e){s(e)&&(e=null),o&&o.apply(this,arguments)}))}:t}function u(t){return t?function(n,r,u){try{return t.call(e,n,r,u)}catch(e){if(!s(e))throw e}}:t}function o(t){return t?function(n,r,u){function o(e,t){t&&(t.uid<0&&(t.uid+=4294967296),t.gid<0&&(t.gid+=4294967296)),u&&u.apply(this,arguments)}return"function"==typeof r&&(u=r,r=null),r?t.call(e,n,r,o):t.call(e,n,o)}:t}function i(t){return t?function(n,r){var u=r?t.call(e,n,r):t.call(e,n);return u&&(u.uid<0&&(u.uid+=4294967296),u.gid<0&&(u.gid+=4294967296)),u}:t}function s(e){return!e||("ENOSYS"===e.code||!(process.getuid&&0===process.getuid()||"EINVAL"!==e.code&&"EPERM"!==e.code))}e.read="function"!=typeof e.read?e.read:function(t){function n(n,r,u,o,i,s){var c;if(s&&"function"==typeof s){var a=0;c=function(l,f,d){if(l&&"EAGAIN"===l.code&&a<10)return a++,t.call(e,n,r,u,o,i,c);s.apply(this,arguments)}}return t.call(e,n,r,u,o,i,c)}return Object.setPrototypeOf&&Object.setPrototypeOf(n,t),n}(e.read),e.readSync="function"!=typeof e.readSync?e.readSync:(c=e.readSync,function(t,n,r,u,o){for(var i=0;;)try{return c.call(e,t,n,r,u,o)}catch(e){if("EAGAIN"===e.code&&i<10){i++;continue}throw e}});var c};var le=C.default.Stream,fe=function(e){return{ReadStream:function t(n,r){if(!(this instanceof t))return new t(n,r);le.call(this);var u=this;this.path=n,this.fd=null,this.readable=!0,this.paused=!1,this.flags="r",this.mode=438,this.bufferSize=65536,r=r||{};for(var o=Object.keys(r),i=0,s=o.length;ithis.end)throw new Error("start must be <= end");this.pos=this.start}if(null!==this.fd)return void process.nextTick((function(){u._read()}));e.open(this.path,this.flags,this.mode,(function(e,t){if(e)return u.emit("error",e),void(u.readable=!1);u.fd=t,u.emit("open",t),u._read()}))},WriteStream:function t(n,r){if(!(this instanceof t))return new t(n,r);le.call(this),this.path=n,this.fd=null,this.writable=!0,this.flags="w",this.encoding="binary",this.mode=438,this.bytesWritten=0,r=r||{};for(var u=Object.keys(r),o=0,i=u.length;o= zero");this.pos=this.start}this.busy=!1,this._queue=[],null===this.fd&&(this._open=e.open,this._queue.push([this._open,this.path,this.flags,this.mode,void 0]),this.flush())}}};var de=function(e){if(null===e||"object"!=typeof e)return e;if(e instanceof Object)var t={__proto__:De(e)};else t=Object.create(null);return Object.getOwnPropertyNames(e).forEach((function(n){Object.defineProperty(t,n,Object.getOwnPropertyDescriptor(e,n))})),t},De=Object.getPrototypeOf||function(e){return e.__proto__};var pe,Ee,me=D.default,he=ae,ye=fe,Ce=de,Fe=F.default;function ge(e,t){Object.defineProperty(e,pe,{get:function(){return t}})}"function"==typeof Symbol&&"function"==typeof Symbol.for?(pe=Symbol.for("graceful-fs.queue"),Ee=Symbol.for("graceful-fs.previous")):(pe="___graceful-fs.queue",Ee="___graceful-fs.previous");var Ae=function(){};if(Fe.debuglog?Ae=Fe.debuglog("gfs4"):/\bgfs4\b/i.test(process.env.NODE_DEBUG||"")&&(Ae=function(){var e=Fe.format.apply(Fe,arguments);e="GFS4: "+e.split(/\n/).join("\nGFS4: "),console.error(e)}),!me[pe]){var ve=w[pe]||[];ge(me,ve),me.close=function(e){function t(t,n){return e.call(me,t,(function(e){e||_e(),"function"==typeof n&&n.apply(this,arguments)}))}return Object.defineProperty(t,Ee,{value:e}),t}(me.close),me.closeSync=function(e){function t(t){e.apply(me,arguments),_e()}return Object.defineProperty(t,Ee,{value:e}),t}(me.closeSync),/\bgfs4\b/i.test(process.env.NODE_DEBUG||"")&&process.on("exit",(function(){Ae(me[pe]),g.default.equal(me[pe].length,0)}))}w[pe]||ge(w,me[pe]);var Se,we=Oe(Ce(me));function Oe(e){he(e),e.gracefulify=Oe,e.createReadStream=function(t,n){return new e.ReadStream(t,n)},e.createWriteStream=function(t,n){return new e.WriteStream(t,n)};var t=e.readFile;e.readFile=function(e,n,r){"function"==typeof n&&(r=n,n=null);return function e(n,r,u,o){return t(n,r,(function(t){!t||"EMFILE"!==t.code&&"ENFILE"!==t.code?"function"==typeof u&&u.apply(this,arguments):be([e,[n,r,u],t,o||Date.now(),Date.now()])}))}(e,n,r)};var n=e.writeFile;e.writeFile=function(e,t,r,u){"function"==typeof r&&(u=r,r=null);return function e(t,r,u,o,i){return n(t,r,u,(function(n){!n||"EMFILE"!==n.code&&"ENFILE"!==n.code?"function"==typeof o&&o.apply(this,arguments):be([e,[t,r,u,o],n,i||Date.now(),Date.now()])}))}(e,t,r,u)};var r=e.appendFile;r&&(e.appendFile=function(e,t,n,u){"function"==typeof n&&(u=n,n=null);return function e(t,n,u,o,i){return r(t,n,u,(function(r){!r||"EMFILE"!==r.code&&"ENFILE"!==r.code?"function"==typeof o&&o.apply(this,arguments):be([e,[t,n,u,o],r,i||Date.now(),Date.now()])}))}(e,t,n,u)});var u=e.copyFile;u&&(e.copyFile=function(e,t,n,r){"function"==typeof n&&(r=n,n=0);return function e(t,n,r,o,i){return u(t,n,r,(function(u){!u||"EMFILE"!==u.code&&"ENFILE"!==u.code?"function"==typeof o&&o.apply(this,arguments):be([e,[t,n,r,o],u,i||Date.now(),Date.now()])}))}(e,t,n,r)});var o=e.readdir;e.readdir=function(e,t,n){"function"==typeof t&&(n=t,t=null);var r=i.test(process.version)?function(e,t,n,r){return o(e,u(e,t,n,r))}:function(e,t,n,r){return o(e,t,u(e,t,n,r))};return r(e,t,n);function u(e,t,n,u){return function(o,i){!o||"EMFILE"!==o.code&&"ENFILE"!==o.code?(i&&i.sort&&i.sort(),"function"==typeof n&&n.call(this,o,i)):be([r,[e,t,n],o,u||Date.now(),Date.now()])}}};var i=/^v[0-5]\./;if("v0.8"===process.version.substr(0,4)){var s=ye(e);d=s.ReadStream,D=s.WriteStream}var c=e.ReadStream;c&&(d.prototype=Object.create(c.prototype),d.prototype.open=function(){var e=this;E(e.path,e.flags,e.mode,(function(t,n){t?(e.autoClose&&e.destroy(),e.emit("error",t)):(e.fd=n,e.emit("open",n),e.read())}))});var a=e.WriteStream;a&&(D.prototype=Object.create(a.prototype),D.prototype.open=function(){var e=this;E(e.path,e.flags,e.mode,(function(t,n){t?(e.destroy(),e.emit("error",t)):(e.fd=n,e.emit("open",n))}))}),Object.defineProperty(e,"ReadStream",{get:function(){return d},set:function(e){d=e},enumerable:!0,configurable:!0}),Object.defineProperty(e,"WriteStream",{get:function(){return D},set:function(e){D=e},enumerable:!0,configurable:!0});var l=d;Object.defineProperty(e,"FileReadStream",{get:function(){return l},set:function(e){l=e},enumerable:!0,configurable:!0});var f=D;function d(e,t){return this instanceof d?(c.apply(this,arguments),this):d.apply(Object.create(d.prototype),arguments)}function D(e,t){return this instanceof D?(a.apply(this,arguments),this):D.apply(Object.create(D.prototype),arguments)}Object.defineProperty(e,"FileWriteStream",{get:function(){return f},set:function(e){f=e},enumerable:!0,configurable:!0});var p=e.open;function E(e,t,n,r){return"function"==typeof n&&(r=n,n=null),function e(t,n,r,u,o){return p(t,n,r,(function(i,s){!i||"EMFILE"!==i.code&&"ENFILE"!==i.code?"function"==typeof u&&u.apply(this,arguments):be([e,[t,n,r,u],i,o||Date.now(),Date.now()])}))}(e,t,n,r)}return e.open=E,e}function be(e){Ae("ENQUEUE",e[0].name,e[1]),me[pe].push(e),Be()}function _e(){for(var e=Date.now(),t=0;t2&&(me[pe][t][3]=e,me[pe][t][4]=e);Be()}function Be(){if(clearTimeout(Se),Se=void 0,0!==me[pe].length){var e=me[pe].shift(),t=e[0],n=e[1],r=e[2],u=e[3],o=e[4];if(void 0===u)Ae("RETRY",t.name,n),t.apply(null,n);else if(Date.now()-u>=6e4){Ae("TIMEOUT",t.name,n);var i=n.pop();"function"==typeof i&&i.call(null,r)}else{var s=Date.now()-o,c=Math.max(o-u,1);s>=Math.min(1.2*c,100)?(Ae("RETRY",t.name,n),t.apply(null,n.concat([u]))):me[pe].push(e)}void 0===Se&&(Se=setTimeout(Be,0))}}process.env.TEST_GRACEFUL_FS_GLOBAL_PATCH&&!me.__patched&&(we=Oe(me),me.__patched=!0),function(e){const t=re.fromCallback,n=we,r=["access","appendFile","chmod","chown","close","copyFile","fchmod","fchown","fdatasync","fstat","fsync","ftruncate","futimes","lchmod","lchown","link","lstat","mkdir","mkdtemp","open","opendir","readdir","readFile","readlink","realpath","rename","rm","rmdir","stat","symlink","truncate","unlink","utimes","writeFile"].filter((e=>"function"==typeof n[e]));Object.assign(e,n),r.forEach((r=>{e[r]=t(n[r])})),e.realpath.native=t(n.realpath.native),e.exists=function(e,t){return"function"==typeof t?n.exists(e,t):new Promise((t=>n.exists(e,t)))},e.read=function(e,t,r,u,o,i){return"function"==typeof i?n.read(e,t,r,u,o,i):new Promise(((i,s)=>{n.read(e,t,r,u,o,((e,t,n)=>{if(e)return s(e);i({bytesRead:t,buffer:n})}))}))},e.write=function(e,t,...r){return"function"==typeof r[r.length-1]?n.write(e,t,...r):new Promise(((u,o)=>{n.write(e,t,...r,((e,t,n)=>{if(e)return o(e);u({bytesWritten:t,buffer:n})}))}))},"function"==typeof n.writev&&(e.writev=function(e,t,...r){return"function"==typeof r[r.length-1]?n.writev(e,t,...r):new Promise(((u,o)=>{n.writev(e,t,...r,((e,t,n)=>{if(e)return o(e);u({bytesWritten:t,buffers:n})}))}))})}(ne);var Pe={},ke={};const xe=p.default;ke.checkPath=function(e){if("win32"===process.platform){if(/[<>:"|?*]/.test(e.replace(xe.parse(e).root,""))){const t=new Error(`Path contains invalid characters: ${e}`);throw t.code="EINVAL",t}}};const Ne=ne,{checkPath:Ie}=ke,Te=e=>"number"==typeof e?e:{mode:511,...e}.mode;Pe.makeDir=async(e,t)=>(Ie(e),Ne.mkdir(e,{mode:Te(t),recursive:!0})),Pe.makeDirSync=(e,t)=>(Ie(e),Ne.mkdirSync(e,{mode:Te(t),recursive:!0}));const Re=re.fromPromise,{makeDir:Me,makeDirSync:Le}=Pe,je=Re(Me);var $e={mkdirs:je,mkdirsSync:Le,mkdirp:je,mkdirpSync:Le,ensureDir:je,ensureDirSync:Le};const He=re.fromPromise,Je=ne;var Ge={pathExists:He((function(e){return Je.access(e).then((()=>!0)).catch((()=>!1))})),pathExistsSync:Je.existsSync};const Ve=we;var Ue=function(e,t,n,r){Ve.open(e,"r+",((e,u)=>{if(e)return r(e);Ve.futimes(u,t,n,(e=>{Ve.close(u,(t=>{r&&r(e||t)}))}))}))},We=function(e,t,n){const r=Ve.openSync(e,"r+");return Ve.futimesSync(r,t,n),Ve.closeSync(r)};const ze=ne,Ke=p.default,qe=F.default;function Ye(e,t,n){const r=n.dereference?e=>ze.stat(e,{bigint:!0}):e=>ze.lstat(e,{bigint:!0});return Promise.all([r(e),r(t).catch((e=>{if("ENOENT"===e.code)return null;throw e}))]).then((([e,t])=>({srcStat:e,destStat:t})))}function Xe(e,t){return t.ino&&t.dev&&t.ino===e.ino&&t.dev===e.dev}function Ze(e,t){const n=Ke.resolve(e).split(Ke.sep).filter((e=>e)),r=Ke.resolve(t).split(Ke.sep).filter((e=>e));return n.reduce(((e,t,n)=>e&&r[n]===t),!0)}function Qe(e,t,n){return`Cannot ${n} '${e}' to a subdirectory of itself, '${t}'.`}var et={checkPaths:function(e,t,n,r,u){qe.callbackify(Ye)(e,t,r,((r,o)=>{if(r)return u(r);const{srcStat:i,destStat:s}=o;if(s){if(Xe(i,s)){const r=Ke.basename(e),o=Ke.basename(t);return"move"===n&&r!==o&&r.toLowerCase()===o.toLowerCase()?u(null,{srcStat:i,destStat:s,isChangingCase:!0}):u(new Error("Source and destination must not be the same."))}if(i.isDirectory()&&!s.isDirectory())return u(new Error(`Cannot overwrite non-directory '${t}' with directory '${e}'.`));if(!i.isDirectory()&&s.isDirectory())return u(new Error(`Cannot overwrite directory '${t}' with non-directory '${e}'.`))}return i.isDirectory()&&Ze(e,t)?u(new Error(Qe(e,t,n))):u(null,{srcStat:i,destStat:s})}))},checkPathsSync:function(e,t,n,r){const{srcStat:u,destStat:o}=function(e,t,n){let r;const u=n.dereference?e=>ze.statSync(e,{bigint:!0}):e=>ze.lstatSync(e,{bigint:!0}),o=u(e);try{r=u(t)}catch(e){if("ENOENT"===e.code)return{srcStat:o,destStat:null};throw e}return{srcStat:o,destStat:r}}(e,t,r);if(o){if(Xe(u,o)){const r=Ke.basename(e),i=Ke.basename(t);if("move"===n&&r!==i&&r.toLowerCase()===i.toLowerCase())return{srcStat:u,destStat:o,isChangingCase:!0};throw new Error("Source and destination must not be the same.")}if(u.isDirectory()&&!o.isDirectory())throw new Error(`Cannot overwrite non-directory '${t}' with directory '${e}'.`);if(!u.isDirectory()&&o.isDirectory())throw new Error(`Cannot overwrite directory '${t}' with non-directory '${e}'.`)}if(u.isDirectory()&&Ze(e,t))throw new Error(Qe(e,t,n));return{srcStat:u,destStat:o}},checkParentPaths:function e(t,n,r,u,o){const i=Ke.resolve(Ke.dirname(t)),s=Ke.resolve(Ke.dirname(r));if(s===i||s===Ke.parse(s).root)return o();ze.stat(s,{bigint:!0},((i,c)=>i?"ENOENT"===i.code?o():o(i):Xe(n,c)?o(new Error(Qe(t,r,u))):e(t,n,s,u,o)))},checkParentPathsSync:function e(t,n,r,u){const o=Ke.resolve(Ke.dirname(t)),i=Ke.resolve(Ke.dirname(r));if(i===o||i===Ke.parse(i).root)return;let s;try{s=ze.statSync(i,{bigint:!0})}catch(e){if("ENOENT"===e.code)return;throw e}if(Xe(n,s))throw new Error(Qe(t,r,u));return e(t,n,i,u)},isSrcSubdir:Ze,areIdentical:Xe};const tt=we,nt=p.default,rt=$e.mkdirs,ut=Ge.pathExists,ot=Ue,it=et;function st(e,t,n,r,u){const o=nt.dirname(n);ut(o,((i,s)=>i?u(i):s?at(e,t,n,r,u):void rt(o,(o=>o?u(o):at(e,t,n,r,u)))))}function ct(e,t,n,r,u,o){Promise.resolve(u.filter(n,r)).then((i=>i?e(t,n,r,u,o):o()),(e=>o(e)))}function at(e,t,n,r,u){(r.dereference?tt.stat:tt.lstat)(t,((o,i)=>o?u(o):i.isDirectory()?function(e,t,n,r,u,o){return t?Dt(n,r,u,o):function(e,t,n,r,u){tt.mkdir(n,(o=>{if(o)return u(o);Dt(t,n,r,(t=>t?u(t):dt(n,e,u)))}))}(e.mode,n,r,u,o)}(i,e,t,n,r,u):i.isFile()||i.isCharacterDevice()||i.isBlockDevice()?function(e,t,n,r,u,o){return t?function(e,t,n,r,u){if(!r.overwrite)return r.errorOnExist?u(new Error(`'${n}' already exists`)):u();tt.unlink(n,(o=>o?u(o):lt(e,t,n,r,u)))}(e,n,r,u,o):lt(e,n,r,u,o)}(i,e,t,n,r,u):i.isSymbolicLink()?function(e,t,n,r,u){tt.readlink(t,((t,o)=>t?u(t):(r.dereference&&(o=nt.resolve(process.cwd(),o)),e?void tt.readlink(n,((t,i)=>t?"EINVAL"===t.code||"UNKNOWN"===t.code?tt.symlink(o,n,u):u(t):(r.dereference&&(i=nt.resolve(process.cwd(),i)),it.isSrcSubdir(o,i)?u(new Error(`Cannot copy '${o}' to a subdirectory of itself, '${i}'.`)):e.isDirectory()&&it.isSrcSubdir(i,o)?u(new Error(`Cannot overwrite '${i}' with '${o}'.`)):function(e,t,n){tt.unlink(t,(r=>r?n(r):tt.symlink(e,t,n)))}(o,n,u)))):tt.symlink(o,n,u))))}(e,t,n,r,u):i.isSocket()?u(new Error(`Cannot copy a socket file: ${t}`)):i.isFIFO()?u(new Error(`Cannot copy a FIFO pipe: ${t}`)):u(new Error(`Unknown file: ${t}`))))}function lt(e,t,n,r,u){tt.copyFile(t,n,(o=>o?u(o):r.preserveTimestamps?function(e,t,n,r){if(function(e){return 0==(128&e)}(e))return function(e,t,n){return dt(e,128|t,n)}(n,e,(u=>u?r(u):ft(e,t,n,r)));return ft(e,t,n,r)}(e.mode,t,n,u):dt(n,e.mode,u)))}function ft(e,t,n,r){!function(e,t,n){tt.stat(e,((e,r)=>e?n(e):ot(t,r.atime,r.mtime,n)))}(t,n,(t=>t?r(t):dt(n,e,r)))}function dt(e,t,n){return tt.chmod(e,t,n)}function Dt(e,t,n,r){tt.readdir(e,((u,o)=>u?r(u):pt(o,e,t,n,r)))}function pt(e,t,n,r,u){const o=e.pop();return o?function(e,t,n,r,u,o){const i=nt.join(n,t),s=nt.join(r,t);it.checkPaths(i,s,"copy",u,((t,c)=>{if(t)return o(t);const{destStat:a}=c;!function(e,t,n,r,u){r.filter?ct(at,e,t,n,r,u):at(e,t,n,r,u)}(a,i,s,u,(t=>t?o(t):pt(e,n,r,u,o)))}))}(e,o,t,n,r,u):u()}var Et=function(e,t,n,r){"function"!=typeof n||r?"function"==typeof n&&(n={filter:n}):(r=n,n={}),r=r||function(){},(n=n||{}).clobber=!("clobber"in n)||!!n.clobber,n.overwrite="overwrite"in n?!!n.overwrite:n.clobber,n.preserveTimestamps&&"ia32"===process.arch&&console.warn("fs-extra: Using the preserveTimestamps option in 32-bit node is not recommended;\n\n see https://github.com/jprichardson/node-fs-extra/issues/269"),it.checkPaths(e,t,"copy",n,((u,o)=>{if(u)return r(u);const{srcStat:i,destStat:s}=o;it.checkParentPaths(e,i,t,"copy",(u=>u?r(u):n.filter?ct(st,s,e,t,n,r):st(s,e,t,n,r)))}))};const mt=we,ht=p.default,yt=$e.mkdirsSync,Ct=We,Ft=et;function gt(e,t,n,r){const u=(r.dereference?mt.statSync:mt.lstatSync)(t);if(u.isDirectory())return function(e,t,n,r,u){return t?St(n,r,u):function(e,t,n,r){return mt.mkdirSync(n),St(t,n,r),vt(n,e)}(e.mode,n,r,u)}(u,e,t,n,r);if(u.isFile()||u.isCharacterDevice()||u.isBlockDevice())return function(e,t,n,r,u){return t?function(e,t,n,r){if(r.overwrite)return mt.unlinkSync(n),At(e,t,n,r);if(r.errorOnExist)throw new Error(`'${n}' already exists`)}(e,n,r,u):At(e,n,r,u)}(u,e,t,n,r);if(u.isSymbolicLink())return function(e,t,n,r){let u=mt.readlinkSync(t);r.dereference&&(u=ht.resolve(process.cwd(),u));if(e){let e;try{e=mt.readlinkSync(n)}catch(e){if("EINVAL"===e.code||"UNKNOWN"===e.code)return mt.symlinkSync(u,n);throw e}if(r.dereference&&(e=ht.resolve(process.cwd(),e)),Ft.isSrcSubdir(u,e))throw new Error(`Cannot copy '${u}' to a subdirectory of itself, '${e}'.`);if(mt.statSync(n).isDirectory()&&Ft.isSrcSubdir(e,u))throw new Error(`Cannot overwrite '${e}' with '${u}'.`);return function(e,t){return mt.unlinkSync(t),mt.symlinkSync(e,t)}(u,n)}return mt.symlinkSync(u,n)}(e,t,n,r);if(u.isSocket())throw new Error(`Cannot copy a socket file: ${t}`);if(u.isFIFO())throw new Error(`Cannot copy a FIFO pipe: ${t}`);throw new Error(`Unknown file: ${t}`)}function At(e,t,n,r){return mt.copyFileSync(t,n),r.preserveTimestamps&&function(e,t,n){(function(e){return 0==(128&e)})(e)&&function(e,t){vt(e,128|t)}(n,e);(function(e,t){const n=mt.statSync(e);Ct(t,n.atime,n.mtime)})(t,n)}(e.mode,t,n),vt(n,e.mode)}function vt(e,t){return mt.chmodSync(e,t)}function St(e,t,n){mt.readdirSync(e).forEach((r=>function(e,t,n,r){const u=ht.join(t,e),o=ht.join(n,e),{destStat:i}=Ft.checkPathsSync(u,o,"copy",r);return function(e,t,n,r){if(!r.filter||r.filter(t,n))return gt(e,t,n,r)}(i,u,o,r)}(r,e,t,n)))}var wt=function(e,t,n){"function"==typeof n&&(n={filter:n}),(n=n||{}).clobber=!("clobber"in n)||!!n.clobber,n.overwrite="overwrite"in n?!!n.overwrite:n.clobber,n.preserveTimestamps&&"ia32"===process.arch&&console.warn("fs-extra: Using the preserveTimestamps option in 32-bit node is not recommended;\n\n see https://github.com/jprichardson/node-fs-extra/issues/269");const{srcStat:r,destStat:u}=Ft.checkPathsSync(e,t,"copy",n);return Ft.checkParentPathsSync(e,r,t,"copy"),function(e,t,n,r){if(r.filter&&!r.filter(t,n))return;const u=ht.dirname(n);mt.existsSync(u)||yt(u);return gt(e,t,n,r)}(u,e,t,n)};var Ot={copy:(0,re.fromCallback)(Et),copySync:wt};const bt=we,_t=p.default,Bt=g.default,Pt="win32"===process.platform;function kt(e){["unlink","chmod","stat","lstat","rmdir","readdir"].forEach((t=>{e[t]=e[t]||bt[t],e[t+="Sync"]=e[t]||bt[t]})),e.maxBusyTries=e.maxBusyTries||3}function xt(e,t,n){let r=0;"function"==typeof t&&(n=t,t={}),Bt(e,"rimraf: missing path"),Bt.strictEqual(typeof e,"string","rimraf: path should be a string"),Bt.strictEqual(typeof n,"function","rimraf: callback function required"),Bt(t,"rimraf: invalid options argument provided"),Bt.strictEqual(typeof t,"object","rimraf: options should be object"),kt(t),Nt(e,t,(function u(o){if(o){if(("EBUSY"===o.code||"ENOTEMPTY"===o.code||"EPERM"===o.code)&&rNt(e,t,u)),100*r)}"ENOENT"===o.code&&(o=null)}n(o)}))}function Nt(e,t,n){Bt(e),Bt(t),Bt("function"==typeof n),t.lstat(e,((r,u)=>r&&"ENOENT"===r.code?n(null):r&&"EPERM"===r.code&&Pt?It(e,t,r,n):u&&u.isDirectory()?Rt(e,t,r,n):void t.unlink(e,(r=>{if(r){if("ENOENT"===r.code)return n(null);if("EPERM"===r.code)return Pt?It(e,t,r,n):Rt(e,t,r,n);if("EISDIR"===r.code)return Rt(e,t,r,n)}return n(r)}))))}function It(e,t,n,r){Bt(e),Bt(t),Bt("function"==typeof r),t.chmod(e,438,(u=>{u?r("ENOENT"===u.code?null:n):t.stat(e,((u,o)=>{u?r("ENOENT"===u.code?null:n):o.isDirectory()?Rt(e,t,n,r):t.unlink(e,r)}))}))}function Tt(e,t,n){let r;Bt(e),Bt(t);try{t.chmodSync(e,438)}catch(e){if("ENOENT"===e.code)return;throw n}try{r=t.statSync(e)}catch(e){if("ENOENT"===e.code)return;throw n}r.isDirectory()?Lt(e,t,n):t.unlinkSync(e)}function Rt(e,t,n,r){Bt(e),Bt(t),Bt("function"==typeof r),t.rmdir(e,(u=>{!u||"ENOTEMPTY"!==u.code&&"EEXIST"!==u.code&&"EPERM"!==u.code?u&&"ENOTDIR"===u.code?r(n):r(u):function(e,t,n){Bt(e),Bt(t),Bt("function"==typeof n),t.readdir(e,((r,u)=>{if(r)return n(r);let o,i=u.length;if(0===i)return t.rmdir(e,n);u.forEach((r=>{xt(_t.join(e,r),t,(r=>{if(!o)return r?n(o=r):void(0==--i&&t.rmdir(e,n))}))}))}))}(e,t,r)}))}function Mt(e,t){let n;kt(t=t||{}),Bt(e,"rimraf: missing path"),Bt.strictEqual(typeof e,"string","rimraf: path should be a string"),Bt(t,"rimraf: missing options"),Bt.strictEqual(typeof t,"object","rimraf: options should be object");try{n=t.lstatSync(e)}catch(n){if("ENOENT"===n.code)return;"EPERM"===n.code&&Pt&&Tt(e,t,n)}try{n&&n.isDirectory()?Lt(e,t,null):t.unlinkSync(e)}catch(n){if("ENOENT"===n.code)return;if("EPERM"===n.code)return Pt?Tt(e,t,n):Lt(e,t,n);if("EISDIR"!==n.code)throw n;Lt(e,t,n)}}function Lt(e,t,n){Bt(e),Bt(t);try{t.rmdirSync(e)}catch(r){if("ENOTDIR"===r.code)throw n;if("ENOTEMPTY"===r.code||"EEXIST"===r.code||"EPERM"===r.code)!function(e,t){if(Bt(e),Bt(t),t.readdirSync(e).forEach((n=>Mt(_t.join(e,n),t))),!Pt){return t.rmdirSync(e,t)}{const n=Date.now();do{try{return t.rmdirSync(e,t)}catch{}}while(Date.now()-n<500)}}(e,t);else if("ENOENT"!==r.code)throw r}}var jt=xt;xt.sync=Mt;const $t=we,Ht=re.fromCallback,Jt=jt;var Gt={remove:Ht((function(e,t){if($t.rm)return $t.rm(e,{recursive:!0,force:!0},t);Jt(e,t)})),removeSync:function(e){if($t.rmSync)return $t.rmSync(e,{recursive:!0,force:!0});Jt.sync(e)}};const Vt=re.fromPromise,Ut=ne,Wt=p.default,zt=$e,Kt=Gt,qt=Vt((async function(e){let t;try{t=await Ut.readdir(e)}catch{return zt.mkdirs(e)}return Promise.all(t.map((t=>Kt.remove(Wt.join(e,t)))))}));function Yt(e){let t;try{t=Ut.readdirSync(e)}catch{return zt.mkdirsSync(e)}t.forEach((t=>{t=Wt.join(e,t),Kt.removeSync(t)}))}var Xt={emptyDirSync:Yt,emptydirSync:Yt,emptyDir:qt,emptydir:qt};const Zt=re.fromCallback,Qt=p.default,en=we,tn=$e;var nn={createFile:Zt((function(e,t){function n(){en.writeFile(e,"",(e=>{if(e)return t(e);t()}))}en.stat(e,((r,u)=>{if(!r&&u.isFile())return t();const o=Qt.dirname(e);en.stat(o,((e,r)=>{if(e)return"ENOENT"===e.code?tn.mkdirs(o,(e=>{if(e)return t(e);n()})):t(e);r.isDirectory()?n():en.readdir(o,(e=>{if(e)return t(e)}))}))}))})),createFileSync:function(e){let t;try{t=en.statSync(e)}catch{}if(t&&t.isFile())return;const n=Qt.dirname(e);try{en.statSync(n).isDirectory()||en.readdirSync(n)}catch(e){if(!e||"ENOENT"!==e.code)throw e;tn.mkdirsSync(n)}en.writeFileSync(e,"")}};const rn=re.fromCallback,un=p.default,on=we,sn=$e,cn=Ge.pathExists,{areIdentical:an}=et;var ln={createLink:rn((function(e,t,n){function r(e,t){on.link(e,t,(e=>{if(e)return n(e);n(null)}))}on.lstat(t,((u,o)=>{on.lstat(e,((u,i)=>{if(u)return u.message=u.message.replace("lstat","ensureLink"),n(u);if(o&&an(i,o))return n(null);const s=un.dirname(t);cn(s,((u,o)=>u?n(u):o?r(e,t):void sn.mkdirs(s,(u=>{if(u)return n(u);r(e,t)}))))}))}))})),createLinkSync:function(e,t){let n;try{n=on.lstatSync(t)}catch{}try{const t=on.lstatSync(e);if(n&&an(t,n))return}catch(e){throw e.message=e.message.replace("lstat","ensureLink"),e}const r=un.dirname(t);return on.existsSync(r)||sn.mkdirsSync(r),on.linkSync(e,t)}};const fn=p.default,dn=we,Dn=Ge.pathExists;var pn={symlinkPaths:function(e,t,n){if(fn.isAbsolute(e))return dn.lstat(e,(t=>t?(t.message=t.message.replace("lstat","ensureSymlink"),n(t)):n(null,{toCwd:e,toDst:e})));{const r=fn.dirname(t),u=fn.join(r,e);return Dn(u,((t,o)=>t?n(t):o?n(null,{toCwd:u,toDst:e}):dn.lstat(e,(t=>t?(t.message=t.message.replace("lstat","ensureSymlink"),n(t)):n(null,{toCwd:e,toDst:fn.relative(r,e)})))))}},symlinkPathsSync:function(e,t){let n;if(fn.isAbsolute(e)){if(n=dn.existsSync(e),!n)throw new Error("absolute srcpath does not exist");return{toCwd:e,toDst:e}}{const r=fn.dirname(t),u=fn.join(r,e);if(n=dn.existsSync(u),n)return{toCwd:u,toDst:e};if(n=dn.existsSync(e),!n)throw new Error("relative srcpath does not exist");return{toCwd:e,toDst:fn.relative(r,e)}}}};const En=we;var mn={symlinkType:function(e,t,n){if(n="function"==typeof t?t:n,t="function"!=typeof t&&t)return n(null,t);En.lstat(e,((e,r)=>{if(e)return n(null,"file");t=r&&r.isDirectory()?"dir":"file",n(null,t)}))},symlinkTypeSync:function(e,t){let n;if(t)return t;try{n=En.lstatSync(e)}catch{return"file"}return n&&n.isDirectory()?"dir":"file"}};const hn=re.fromCallback,yn=p.default,Cn=ne,Fn=$e.mkdirs,gn=$e.mkdirsSync,An=pn.symlinkPaths,vn=pn.symlinkPathsSync,Sn=mn.symlinkType,wn=mn.symlinkTypeSync,On=Ge.pathExists,{areIdentical:bn}=et;function _n(e,t,n,r){An(e,t,((u,o)=>{if(u)return r(u);e=o.toDst,Sn(o.toCwd,n,((n,u)=>{if(n)return r(n);const o=yn.dirname(t);On(o,((n,i)=>n?r(n):i?Cn.symlink(e,t,u,r):void Fn(o,(n=>{if(n)return r(n);Cn.symlink(e,t,u,r)}))))}))}))}var Bn={createSymlink:hn((function(e,t,n,r){r="function"==typeof n?n:r,n="function"!=typeof n&&n,Cn.lstat(t,((u,o)=>{!u&&o.isSymbolicLink()?Promise.all([Cn.stat(e),Cn.stat(t)]).then((([u,o])=>{if(bn(u,o))return r(null);_n(e,t,n,r)})):_n(e,t,n,r)}))})),createSymlinkSync:function(e,t,n){let r;try{r=Cn.lstatSync(t)}catch{}if(r&&r.isSymbolicLink()){const n=Cn.statSync(e),r=Cn.statSync(t);if(bn(n,r))return}const u=vn(e,t);e=u.toDst,n=wn(u.toCwd,n);const o=yn.dirname(t);return Cn.existsSync(o)||gn(o),Cn.symlinkSync(e,t,n)}};const{createFile:Pn,createFileSync:kn}=nn,{createLink:xn,createLinkSync:Nn}=ln,{createSymlink:In,createSymlinkSync:Tn}=Bn;var Rn={createFile:Pn,createFileSync:kn,ensureFile:Pn,ensureFileSync:kn,createLink:xn,createLinkSync:Nn,ensureLink:xn,ensureLinkSync:Nn,createSymlink:In,createSymlinkSync:Tn,ensureSymlink:In,ensureSymlinkSync:Tn};var Mn={stringify:function(e,{EOL:t="\n",finalEOL:n=!0,replacer:r=null,spaces:u}={}){const o=n?t:"";return JSON.stringify(e,r,u).replace(/\n/g,t)+o},stripBom:function(e){return Buffer.isBuffer(e)&&(e=e.toString("utf8")),e.replace(/^\uFEFF/,"")}};let Ln;try{Ln=we}catch(e){Ln=D.default}const jn=re,{stringify:$n,stripBom:Hn}=Mn;const Jn=jn.fromPromise((async function(e,t={}){"string"==typeof t&&(t={encoding:t});const n=t.fs||Ln,r=!("throws"in t)||t.throws;let u,o=await jn.fromCallback(n.readFile)(e,t);o=Hn(o);try{u=JSON.parse(o,t?t.reviver:null)}catch(t){if(r)throw t.message=`${e}: ${t.message}`,t;return null}return u}));const Gn=jn.fromPromise((async function(e,t,n={}){const r=n.fs||Ln,u=$n(t,n);await jn.fromCallback(r.writeFile)(e,u,n)}));const Vn={readFile:Jn,readFileSync:function(e,t={}){"string"==typeof t&&(t={encoding:t});const n=t.fs||Ln,r=!("throws"in t)||t.throws;try{let r=n.readFileSync(e,t);return r=Hn(r),JSON.parse(r,t.reviver)}catch(t){if(r)throw t.message=`${e}: ${t.message}`,t;return null}},writeFile:Gn,writeFileSync:function(e,t,n={}){const r=n.fs||Ln,u=$n(t,n);return r.writeFileSync(e,u,n)}};var Un={readJson:Vn.readFile,readJsonSync:Vn.readFileSync,writeJson:Vn.writeFile,writeJsonSync:Vn.writeFileSync};const Wn=re.fromCallback,zn=we,Kn=p.default,qn=$e,Yn=Ge.pathExists;var Xn={outputFile:Wn((function(e,t,n,r){"function"==typeof n&&(r=n,n="utf8");const u=Kn.dirname(e);Yn(u,((o,i)=>o?r(o):i?zn.writeFile(e,t,n,r):void qn.mkdirs(u,(u=>{if(u)return r(u);zn.writeFile(e,t,n,r)}))))})),outputFileSync:function(e,...t){const n=Kn.dirname(e);if(zn.existsSync(n))return zn.writeFileSync(e,...t);qn.mkdirsSync(n),zn.writeFileSync(e,...t)}};const{stringify:Zn}=Mn,{outputFile:Qn}=Xn;var er=async function(e,t,n={}){const r=Zn(t,n);await Qn(e,r,n)};const{stringify:tr}=Mn,{outputFileSync:nr}=Xn;var rr=function(e,t,n){const r=tr(t,n);nr(e,r,n)};const ur=re.fromPromise,or=Un;or.outputJson=ur(er),or.outputJsonSync=rr,or.outputJSON=or.outputJson,or.outputJSONSync=or.outputJsonSync,or.writeJSON=or.writeJson,or.writeJSONSync=or.writeJsonSync,or.readJSON=or.readJson,or.readJSONSync=or.readJsonSync;var ir=or;const sr=we,cr=p.default,ar=Ot.copy,lr=Gt.remove,fr=$e.mkdirp,dr=Ge.pathExists,Dr=et;function pr(e,t,n,r,u){return r?Er(e,t,n,u):n?lr(t,(r=>r?u(r):Er(e,t,n,u))):void dr(t,((r,o)=>r?u(r):o?u(new Error("dest already exists.")):Er(e,t,n,u)))}function Er(e,t,n,r){sr.rename(e,t,(u=>u?"EXDEV"!==u.code?r(u):function(e,t,n,r){const u={overwrite:n,errorOnExist:!0};ar(e,t,u,(t=>t?r(t):lr(e,r)))}(e,t,n,r):r()))}var mr=function(e,t,n,r){"function"==typeof n&&(r=n,n={});const u=n.overwrite||n.clobber||!1;Dr.checkPaths(e,t,"move",n,((n,o)=>{if(n)return r(n);const{srcStat:i,isChangingCase:s=!1}=o;Dr.checkParentPaths(e,i,t,"move",(n=>n?r(n):function(e){const t=cr.dirname(e);return cr.parse(t).root===t}(t)?pr(e,t,u,s,r):void fr(cr.dirname(t),(n=>n?r(n):pr(e,t,u,s,r)))))}))};const hr=we,yr=p.default,Cr=Ot.copySync,Fr=Gt.removeSync,gr=$e.mkdirpSync,Ar=et;function vr(e,t,n){try{hr.renameSync(e,t)}catch(r){if("EXDEV"!==r.code)throw r;return function(e,t,n){const r={overwrite:n,errorOnExist:!0};return Cr(e,t,r),Fr(e)}(e,t,n)}}var Sr=function(e,t,n){const r=(n=n||{}).overwrite||n.clobber||!1,{srcStat:u,isChangingCase:o=!1}=Ar.checkPathsSync(e,t,"move",n);return Ar.checkParentPathsSync(e,u,t,"move"),function(e){const t=yr.dirname(e);return yr.parse(t).root===t}(t)||gr(yr.dirname(t)),function(e,t,n,r){if(r)return vr(e,t,n);if(n)return Fr(t),vr(e,t,n);if(hr.existsSync(t))throw new Error("dest already exists.");return vr(e,t,n)}(e,t,r,o)};var wr,Or,br,_r,Br,Pr={move:(0,re.fromCallback)(mr),moveSync:Sr},kr={...ne,...Ot,...Xt,...Rn,...ir,...$e,...Pr,...Xn,...Ge,...Gt},xr={},Nr={exports:{}},Ir={exports:{}};function Tr(){if(Or)return wr;Or=1;var e=1e3,t=60*e,n=60*t,r=24*n,u=7*r,o=365.25*r;function i(e,t,n,r){var u=t>=1.5*n;return Math.round(e/n)+" "+r+(u?"s":"")}return wr=function(s,c){c=c||{};var a=typeof s;if("string"===a&&s.length>0)return function(i){if((i=String(i)).length>100)return;var s=/^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(i);if(!s)return;var c=parseFloat(s[1]);switch((s[2]||"ms").toLowerCase()){case"years":case"year":case"yrs":case"yr":case"y":return c*o;case"weeks":case"week":case"w":return c*u;case"days":case"day":case"d":return c*r;case"hours":case"hour":case"hrs":case"hr":case"h":return c*n;case"minutes":case"minute":case"mins":case"min":case"m":return c*t;case"seconds":case"second":case"secs":case"sec":case"s":return c*e;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return c;default:return}}(s);if("number"===a&&isFinite(s))return c.long?function(u){var o=Math.abs(u);if(o>=r)return i(u,o,r,"day");if(o>=n)return i(u,o,n,"hour");if(o>=t)return i(u,o,t,"minute");if(o>=e)return i(u,o,e,"second");return u+" ms"}(s):function(u){var o=Math.abs(u);if(o>=r)return Math.round(u/r)+"d";if(o>=n)return Math.round(u/n)+"h";if(o>=t)return Math.round(u/t)+"m";if(o>=e)return Math.round(u/e)+"s";return u+"ms"}(s);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(s))}}function Rr(){if(_r)return br;return _r=1,br=function(e){function t(e){let r,u,o,i=null;function s(...e){if(!s.enabled)return;const n=s,u=Number(new Date),o=u-(r||u);n.diff=o,n.prev=r,n.curr=u,r=u,e[0]=t.coerce(e[0]),"string"!=typeof e[0]&&e.unshift("%O");let i=0;e[0]=e[0].replace(/%([a-zA-Z%])/g,((r,u)=>{if("%%"===r)return"%";i++;const o=t.formatters[u];if("function"==typeof o){const t=e[i];r=o.call(n,t),e.splice(i,1),i--}return r})),t.formatArgs.call(n,e);(n.log||t.log).apply(n,e)}return s.namespace=e,s.useColors=t.useColors(),s.color=t.selectColor(e),s.extend=n,s.destroy=t.destroy,Object.defineProperty(s,"enabled",{enumerable:!0,configurable:!1,get:()=>null!==i?i:(u!==t.namespaces&&(u=t.namespaces,o=t.enabled(e)),o),set:e=>{i=e}}),"function"==typeof t.init&&t.init(s),s}function n(e,n){const r=t(this.namespace+(void 0===n?":":n)+e);return r.log=this.log,r}function r(e){return e.toString().substring(2,e.toString().length-2).replace(/\.\*\?$/,"*")}return t.debug=t,t.default=t,t.coerce=function(e){if(e instanceof Error)return e.stack||e.message;return e},t.disable=function(){const e=[...t.names.map(r),...t.skips.map(r).map((e=>"-"+e))].join(",");return t.enable(""),e},t.enable=function(e){let n;t.save(e),t.namespaces=e,t.names=[],t.skips=[];const r=("string"==typeof e?e:"").split(/[\s,]+/),u=r.length;for(n=0;n{t[n]=e[n]})),t.names=[],t.skips=[],t.formatters={},t.selectColor=function(e){let n=0;for(let t=0;t{const n=e.startsWith("-")?"":1===e.length?"-":"--",r=t.indexOf(n+e),u=t.indexOf("--");return-1!==r&&(-1===u||r{}),"Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."),t.colors=[6,2,3,4,5,1];try{const e=function(){if($r)return jr;$r=1;const e=E.default,t=A.default,n=Vr(),{env:r}=process;let u;function o(e){return 0!==e&&{level:e,hasBasic:!0,has256:e>=2,has16m:e>=3}}function i(t,o){if(0===u)return 0;if(n("color=16m")||n("color=full")||n("color=truecolor"))return 3;if(n("color=256"))return 2;if(t&&!o&&void 0===u)return 0;const i=u||0;if("dumb"===r.TERM)return i;if("win32"===process.platform){const t=e.release().split(".");return Number(t[0])>=10&&Number(t[2])>=10586?Number(t[2])>=14931?3:2:1}if("CI"in r)return["TRAVIS","CIRCLECI","APPVEYOR","GITLAB_CI","GITHUB_ACTIONS","BUILDKITE"].some((e=>e in r))||"codeship"===r.CI_NAME?1:i;if("TEAMCITY_VERSION"in r)return/^(9\.(0*[1-9]\d*)\.|\d{2,}\.)/.test(r.TEAMCITY_VERSION)?1:0;if("truecolor"===r.COLORTERM)return 3;if("TERM_PROGRAM"in r){const e=parseInt((r.TERM_PROGRAM_VERSION||"").split(".")[0],10);switch(r.TERM_PROGRAM){case"iTerm.app":return e>=3?3:2;case"Apple_Terminal":return 2}}return/-256(color)?$/i.test(r.TERM)?2:/^screen|^xterm|^vt100|^vt220|^rxvt|color|ansi|cygwin|linux/i.test(r.TERM)||"COLORTERM"in r?1:i}return n("no-color")||n("no-colors")||n("color=false")||n("color=never")?u=0:(n("color")||n("colors")||n("color=true")||n("color=always"))&&(u=1),"FORCE_COLOR"in r&&(u="true"===r.FORCE_COLOR?1:"false"===r.FORCE_COLOR?0:0===r.FORCE_COLOR.length?1:Math.min(parseInt(r.FORCE_COLOR,10),3)),jr={supportsColor:function(e){return o(i(e,e&&e.isTTY))},stdout:o(i(!0,t.isatty(1))),stderr:o(i(!0,t.isatty(2)))}}();e&&(e.stderr||e).level>=2&&(t.colors=[20,21,26,27,32,33,38,39,40,41,42,43,44,45,56,57,62,63,68,69,74,75,76,77,78,79,80,81,92,93,98,99,112,113,128,129,134,135,148,149,160,161,162,163,164,165,166,167,168,169,170,171,172,173,178,179,184,185,196,197,198,199,200,201,202,203,204,205,206,207,208,209,214,215,220,221])}catch(e){}t.inspectOpts=Object.keys(process.env).filter((e=>/^debug_/i.test(e))).reduce(((e,t)=>{const n=t.substring(6).toLowerCase().replace(/_([a-z])/g,((e,t)=>t.toUpperCase()));let r=process.env[t];return r=!!/^(yes|on|true|enabled)$/i.test(r)||!/^(no|off|false|disabled)$/i.test(r)&&("null"===r?null:Number(r)),e[n]=r,e}),{}),e.exports=Rr()(t);const{formatters:u}=e.exports;u.o=function(e){return this.inspectOpts.colors=this.useColors,r.inspect(e,this.inspectOpts).split("\n").map((e=>e.trim())).join(" ")},u.O=function(e){return this.inspectOpts.colors=this.useColors,r.inspect(e,this.inspectOpts)}}(Gr,Gr.exports)),Gr.exports}Jr=Nr,"undefined"==typeof process||"renderer"===process.type||!0===process.browser||process.__nwjs?Jr.exports=(Br||(Br=1,function(e,t){t.formatArgs=function(t){if(t[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+t[0]+(this.useColors?"%c ":" ")+"+"+e.exports.humanize(this.diff),!this.useColors)return;const n="color: "+this.color;t.splice(1,0,n,"color: inherit");let r=0,u=0;t[0].replace(/%[a-zA-Z%]/g,(e=>{"%%"!==e&&(r++,"%c"===e&&(u=r))})),t.splice(u,0,n)},t.save=function(e){try{e?t.storage.setItem("debug",e):t.storage.removeItem("debug")}catch(e){}},t.load=function(){let e;try{e=t.storage.getItem("debug")}catch(e){}return!e&&"undefined"!=typeof process&&"env"in process&&(e=process.env.DEBUG),e},t.useColors=function(){return!("undefined"==typeof window||!window.process||"renderer"!==window.process.type&&!window.process.__nwjs)||("undefined"==typeof navigator||!navigator.userAgent||!navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/))&&("undefined"!=typeof document&&document.documentElement&&document.documentElement.style&&document.documentElement.style.WebkitAppearance||"undefined"!=typeof window&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||"undefined"!=typeof navigator&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/)&&parseInt(RegExp.$1,10)>=31||"undefined"!=typeof navigator&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/))},t.storage=function(){try{return localStorage}catch(e){}}(),t.destroy=(()=>{let e=!1;return()=>{e||(e=!0,console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."))}})(),t.colors=["#0000CC","#0000FF","#0033CC","#0033FF","#0066CC","#0066FF","#0099CC","#0099FF","#00CC00","#00CC33","#00CC66","#00CC99","#00CCCC","#00CCFF","#3300CC","#3300FF","#3333CC","#3333FF","#3366CC","#3366FF","#3399CC","#3399FF","#33CC00","#33CC33","#33CC66","#33CC99","#33CCCC","#33CCFF","#6600CC","#6600FF","#6633CC","#6633FF","#66CC00","#66CC33","#9900CC","#9900FF","#9933CC","#9933FF","#99CC00","#99CC33","#CC0000","#CC0033","#CC0066","#CC0099","#CC00CC","#CC00FF","#CC3300","#CC3333","#CC3366","#CC3399","#CC33CC","#CC33FF","#CC6600","#CC6633","#CC9900","#CC9933","#CCCC00","#CCCC33","#FF0000","#FF0033","#FF0066","#FF0099","#FF00CC","#FF00FF","#FF3300","#FF3333","#FF3366","#FF3399","#FF33CC","#FF33FF","#FF6600","#FF6633","#FF9900","#FF9933","#FFCC00","#FFCC33"],t.log=console.debug||console.log||(()=>{}),e.exports=Rr()(t);const{formatters:n}=e.exports;n.j=function(e){try{return JSON.stringify(e)}catch(e){return"[UnexpectedJSONParseError]: "+e.message}}}(Ir,Ir.exports)),Ir.exports):Jr.exports=Ur();var Wr=function(e){return(e=e||{}).circles?function(e){var t=[],n=[];return e.proto?function e(u){if("object"!=typeof u||null===u)return u;if(u instanceof Date)return new Date(u);if(Array.isArray(u))return r(u,e);if(u instanceof Map)return new Map(r(Array.from(u),e));if(u instanceof Set)return new Set(r(Array.from(u),e));var o={};for(var i in t.push(u),n.push(o),u){var s=u[i];if("object"!=typeof s||null===s)o[i]=s;else if(s instanceof Date)o[i]=new Date(s);else if(s instanceof Map)o[i]=new Map(r(Array.from(s),e));else if(s instanceof Set)o[i]=new Set(r(Array.from(s),e));else if(ArrayBuffer.isView(s))o[i]=zr(s);else{var c=t.indexOf(s);o[i]=-1!==c?n[c]:e(s)}}return t.pop(),n.pop(),o}:function e(u){if("object"!=typeof u||null===u)return u;if(u instanceof Date)return new Date(u);if(Array.isArray(u))return r(u,e);if(u instanceof Map)return new Map(r(Array.from(u),e));if(u instanceof Set)return new Set(r(Array.from(u),e));var o={};for(var i in t.push(u),n.push(o),u)if(!1!==Object.hasOwnProperty.call(u,i)){var s=u[i];if("object"!=typeof s||null===s)o[i]=s;else if(s instanceof Date)o[i]=new Date(s);else if(s instanceof Map)o[i]=new Map(r(Array.from(s),e));else if(s instanceof Set)o[i]=new Set(r(Array.from(s),e));else if(ArrayBuffer.isView(s))o[i]=zr(s);else{var c=t.indexOf(s);o[i]=-1!==c?n[c]:e(s)}}return t.pop(),n.pop(),o};function r(e,r){for(var u=Object.keys(e),o=new Array(u.length),i=0;i!e,Qr=e=>e&&"object"==typeof e&&!Array.isArray(e),eu=(e,t,n)=>{(Array.isArray(t)?t:[t]).forEach((t=>{if(t)throw new Error(`Problem with log4js configuration: (${Kr.inspect(e,{depth:5})}) - ${n}`)}))};var tu={configure:e=>{qr("New configuration to be validated: ",e),eu(e,Zr(Qr(e)),"must be an object."),qr(`Calling pre-processing listeners (${Yr.length})`),Yr.forEach((t=>t(e))),qr("Configuration pre-processing finished."),qr(`Calling configuration listeners (${Xr.length})`),Xr.forEach((t=>t(e))),qr("Configuration finished.")},addListener:e=>{Xr.push(e),qr(`Added listener, now ${Xr.length} listeners`)},addPreProcessingListener:e=>{Yr.push(e),qr(`Added pre-processing listener, now ${Yr.length} listeners`)},throwExceptionIf:eu,anObject:Qr,anInteger:e=>e&&"number"==typeof e&&Number.isInteger(e),validIdentifier:e=>/^[A-Za-z][A-Za-z0-9_]*$/g.test(e),not:Zr},nu={exports:{}};!function(e){function t(e,t){for(var n=e.toString();n.length-1?s:c,l=n(u.getHours()),f=n(u.getMinutes()),d=n(u.getSeconds()),D=t(u.getMilliseconds(),3),p=function(e){var t=Math.abs(e),n=String(Math.floor(t/60)),r=String(t%60);return n=("0"+n).slice(-2),r=("0"+r).slice(-2),0===e?"Z":(e<0?"+":"-")+n+":"+r}(u.getTimezoneOffset());return r.replace(/dd/g,o).replace(/MM/g,i).replace(/y{1,4}/g,a).replace(/hh/g,l).replace(/mm/g,f).replace(/ss/g,d).replace(/SSS/g,D).replace(/O/g,p)}function u(e,t,n,r){e["set"+(r?"":"UTC")+t](n)}e.exports=r,e.exports.asString=r,e.exports.parse=function(t,n,r){if(!t)throw new Error("pattern must be supplied");return function(t,n,r){var o=t.indexOf("O")<0,i=!1,s=[{pattern:/y{1,4}/,regexp:"\\d{1,4}",fn:function(e,t){u(e,"FullYear",t,o)}},{pattern:/MM/,regexp:"\\d{1,2}",fn:function(e,t){u(e,"Month",t-1,o),e.getMonth()!==t-1&&(i=!0)}},{pattern:/dd/,regexp:"\\d{1,2}",fn:function(e,t){i&&u(e,"Month",e.getMonth()-1,o),u(e,"Date",t,o)}},{pattern:/hh/,regexp:"\\d{1,2}",fn:function(e,t){u(e,"Hours",t,o)}},{pattern:/mm/,regexp:"\\d\\d",fn:function(e,t){u(e,"Minutes",t,o)}},{pattern:/ss/,regexp:"\\d\\d",fn:function(e,t){u(e,"Seconds",t,o)}},{pattern:/SSS/,regexp:"\\d\\d\\d",fn:function(e,t){u(e,"Milliseconds",t,o)}},{pattern:/O/,regexp:"[+-]\\d{1,2}:?\\d{2}?|Z",fn:function(e,t){t="Z"===t?0:t.replace(":","");var n=Math.abs(t),r=(t>0?-1:1)*(n%100+60*Math.floor(n/100));e.setUTCMinutes(e.getUTCMinutes()+r)}}],c=s.reduce((function(e,t){return t.pattern.test(e.regexp)?(t.index=e.regexp.match(t.pattern).index,e.regexp=e.regexp.replace(t.pattern,"("+t.regexp+")")):t.index=-1,e}),{regexp:t,index:[]}),a=s.filter((function(e){return e.index>-1}));a.sort((function(e,t){return e.index-t.index}));var l=new RegExp(c.regexp).exec(n);if(l){var f=r||e.exports.now();return a.forEach((function(e,t){e.fn(f,l[t+1])})),f}throw new Error("String '"+n+"' could not be parsed as '"+t+"'")}(t,n,r)},e.exports.now=function(){return new Date},e.exports.ISO8601_FORMAT="yyyy-MM-ddThh:mm:ss.SSS",e.exports.ISO8601_WITH_TZ_OFFSET_FORMAT="yyyy-MM-ddThh:mm:ss.SSSO",e.exports.DATETIME_FORMAT="dd MM yyyy hh:mm:ss.SSS",e.exports.ABSOLUTETIME_FORMAT="hh:mm:ss.SSS"}(nu);const ru=nu.exports,uu=E.default,ou=F.default,iu=p.default,su={bold:[1,22],italic:[3,23],underline:[4,24],inverse:[7,27],white:[37,39],grey:[90,39],black:[90,39],blue:[34,39],cyan:[36,39],green:[32,39],magenta:[35,39],red:[91,39],yellow:[33,39]};function cu(e){return e?`[${su[e][0]}m`:""}function au(e){return e?`[${su[e][1]}m`:""}function lu(e,t){return n=ou.format("[%s] [%s] %s - ",ru.asString(e.startTime),e.level.toString(),e.categoryName),cu(r=t)+n+au(r);var n,r}function fu(e){return lu(e)+ou.format(...e.data)}function du(e){return lu(e,e.level.colour)+ou.format(...e.data)}function Du(e){return ou.format(...e.data)}function pu(e){return e.data[0]}function Eu(e,t){const n=/%(-?[0-9]+)?(\.?-?[0-9]+)?([[\]cdhmnprzxXyflos%])(\{([^}]+)\})?|([^%]+)/;function r(e){return e&&e.pid?e.pid.toString():process.pid.toString()}e=e||"%r %p %c - %m%n";const u={c:function(e,t){let n=e.categoryName;if(t){const e=parseInt(t,10),r=n.split(".");ee&&(n=r.slice(-e).join(iu.sep))}return n},l:function(e){return e.lineNumber?`${e.lineNumber}`:""},o:function(e){return e.columnNumber?`${e.columnNumber}`:""},s:function(e){return e.callStack||""}};function o(e,t,n){return u[e](t,n)}function i(e,t,n){let r=e;return r=function(e,t){let n;return e?(n=parseInt(e.substr(1),10),n>0?t.slice(0,n):t.slice(n)):t}(t,r),r=function(e,t){let n;if(e)if("-"===e.charAt(0))for(n=parseInt(e.substr(1),10);t.lengthDu,basic:()=>fu,colored:()=>du,coloured:()=>du,pattern:e=>Eu(e&&e.pattern,e&&e.tokens),dummy:()=>pu};var hu={basicLayout:fu,messagePassThroughLayout:Du,patternLayout:Eu,colouredLayout:du,coloredLayout:du,dummyLayout:pu,addLayout(e,t){mu[e]=t},layout:(e,t)=>mu[e]&&mu[e](t)};const yu=tu,Cu=["white","grey","black","blue","cyan","green","magenta","red","yellow"];class Fu{constructor(e,t,n){this.level=e,this.levelStr=t,this.colour=n}toString(){return this.levelStr}static getLevel(e,t){return e?e instanceof Fu?e:(e instanceof Object&&e.levelStr&&(e=e.levelStr),Fu[e.toString().toUpperCase()]||t):t}static addLevels(e){if(e){Object.keys(e).forEach((t=>{const n=t.toUpperCase();Fu[n]=new Fu(e[t].value,n,e[t].colour);const r=Fu.levels.findIndex((e=>e.levelStr===n));r>-1?Fu.levels[r]=Fu[n]:Fu.levels.push(Fu[n])})),Fu.levels.sort(((e,t)=>e.level-t.level))}}isLessThanOrEqualTo(e){return"string"==typeof e&&(e=Fu.getLevel(e)),this.level<=e.level}isGreaterThanOrEqualTo(e){return"string"==typeof e&&(e=Fu.getLevel(e)),this.level>=e.level}isEqualTo(e){return"string"==typeof e&&(e=Fu.getLevel(e)),this.level===e.level}}Fu.levels=[],Fu.addLevels({ALL:{value:Number.MIN_VALUE,colour:"grey"},TRACE:{value:5e3,colour:"blue"},DEBUG:{value:1e4,colour:"cyan"},INFO:{value:2e4,colour:"green"},WARN:{value:3e4,colour:"yellow"},ERROR:{value:4e4,colour:"red"},FATAL:{value:5e4,colour:"magenta"},MARK:{value:9007199254740992,colour:"grey"},OFF:{value:Number.MAX_VALUE,colour:"grey"}}),yu.addListener((e=>{const t=e.levels;if(t){yu.throwExceptionIf(e,yu.not(yu.anObject(t)),"levels must be an object");Object.keys(t).forEach((n=>{yu.throwExceptionIf(e,yu.not(yu.validIdentifier(n)),`level name "${n}" is not a valid identifier (must start with a letter, only contain A-Z,a-z,0-9,_)`),yu.throwExceptionIf(e,yu.not(yu.anObject(t[n])),`level "${n}" must be an object`),yu.throwExceptionIf(e,yu.not(t[n].value),`level "${n}" must have a 'value' property`),yu.throwExceptionIf(e,yu.not(yu.anInteger(t[n].value)),`level "${n}".value must have an integer value`),yu.throwExceptionIf(e,yu.not(t[n].colour),`level "${n}" must have a 'colour' property`),yu.throwExceptionIf(e,yu.not(Cu.indexOf(t[n].colour)>-1),`level "${n}".colour must be one of ${Cu.join(", ")}`)}))}})),yu.addListener((e=>{Fu.addLevels(e.levels)}));var gu=Fu,Au={exports:{}},vu={};/*! (c) 2020 Andrea Giammarchi */
-const{parse:Su,stringify:wu}=JSON,{keys:Ou}=Object,bu=String,_u="string",Bu={},Pu="object",ku=(e,t)=>t,xu=e=>e instanceof bu?bu(e):e,Nu=(e,t)=>typeof t===_u?new bu(t):t,Iu=(e,t,n,r)=>{const u=[];for(let o=Ou(n),{length:i}=o,s=0;s{const r=bu(t.push(n)-1);return e.set(n,r),r},Ru=(e,t)=>{const n=Su(e,Nu).map(xu),r=n[0],u=t||ku,o=typeof r===Pu&&r?Iu(n,new Set,r,u):r;return u.call({"":o},"",o)};vu.parse=Ru;const Mu=(e,t,n)=>{const r=t&&typeof t===Pu?(e,n)=>""===e||-1Su(Mu(e));vu.fromJSON=e=>Ru(wu(e));const Lu=vu,ju=gu;class $u{constructor(e,t,n,r,u){this.startTime=new Date,this.categoryName=e,this.data=n,this.level=t,this.context=Object.assign({},r),this.pid=process.pid,u&&(this.functionName=u.functionName,this.fileName=u.fileName,this.lineNumber=u.lineNumber,this.columnNumber=u.columnNumber,this.callStack=u.callStack)}serialise(){const e=this.data.map((e=>(e&&e.message&&e.stack&&(e=Object.assign({message:e.message,stack:e.stack},e)),e)));return this.data=e,Lu.stringify(this)}static deserialise(e){let t;try{const n=Lu.parse(e);n.data=n.data.map((e=>{if(e&&e.message&&e.stack){const t=new Error(e);Object.keys(e).forEach((n=>{t[n]=e[n]})),e=t}return e})),t=new $u(n.categoryName,ju.getLevel(n.level.levelStr),n.data,n.context),t.startTime=new Date(n.startTime),t.pid=n.pid,t.cluster=n.cluster}catch(n){t=new $u("log4js",ju.ERROR,["Unable to parse log:",e,"because: ",n])}return t}}var Hu=$u;const Ju=Nr.exports("log4js:clustering"),Gu=Hu,Vu=tu;let Uu=!1,Wu=null;try{Wu=require("cluster")}catch(e){Ju("cluster module not present"),Uu=!0}const zu=[];let Ku=!1,qu="NODE_APP_INSTANCE";const Yu=()=>Ku&&"0"===process.env[qu],Xu=()=>Uu||Wu.isMaster||Yu(),Zu=e=>{zu.forEach((t=>t(e)))},Qu=(e,t)=>{if(Ju("cluster message received from worker ",e,": ",t),e.topic&&e.data&&(t=e,e=void 0),t&&t.topic&&"log4js:message"===t.topic){Ju("received message: ",t.data);const e=Gu.deserialise(t.data);Zu(e)}};Uu||Vu.addListener((e=>{zu.length=0,({pm2:Ku,disableClustering:Uu,pm2InstanceVar:qu="NODE_APP_INSTANCE"}=e),Ju(`clustering disabled ? ${Uu}`),Ju(`cluster.isMaster ? ${Wu&&Wu.isMaster}`),Ju(`pm2 enabled ? ${Ku}`),Ju(`pm2InstanceVar = ${qu}`),Ju(`process.env[${qu}] = ${process.env[qu]}`),Ku&&process.removeListener("message",Qu),Wu&&Wu.removeListener&&Wu.removeListener("message",Qu),Uu||e.disableClustering?Ju("Not listening for cluster messages, because clustering disabled."):Yu()?(Ju("listening for PM2 broadcast messages"),process.on("message",Qu)):Wu.isMaster?(Ju("listening for cluster messages"),Wu.on("message",Qu)):Ju("not listening for messages, because we are not a master process")}));var eo={onlyOnMaster:(e,t)=>Xu()?e():t,isMaster:Xu,send:e=>{Xu()?Zu(e):(Ku||(e.cluster={workerId:Wu.worker.id,worker:process.pid}),process.send({topic:"log4js:message",data:e.serialise()}))},onMessage:e=>{zu.push(e)}},to={};function no(e){if("number"==typeof e&&Number.isInteger(e))return e;const t={K:1024,M:1048576,G:1073741824},n=Object.keys(t),r=e.substr(e.length-1).toLocaleUpperCase(),u=e.substring(0,e.length-1).trim();if(n.indexOf(r)<0||!Number.isInteger(Number(u)))throw Error(`maxLogSize: "${e}" is invalid`);return u*t[r]}function ro(e){return function(e,t){const n=Object.assign({},t);return Object.keys(e).forEach((r=>{n[r]&&(n[r]=e[r](t[r]))})),n}({maxLogSize:no},e)}const uo={file:ro,fileSync:ro};to.modifyConfig=e=>uo[e.type]?uo[e.type](e):e;var oo={};const io=console.log.bind(console);oo.configure=function(e,t){let n=t.colouredLayout;return e.layout&&(n=t.layout(e.layout.type,e.layout)),function(e,t){return n=>{io(e(n,t))}}(n,e.timezoneOffset)};var so={};so.configure=function(e,t){let n=t.colouredLayout;return e.layout&&(n=t.layout(e.layout.type,e.layout)),function(e,t){return n=>{process.stdout.write(`${e(n,t)}\n`)}}(n,e.timezoneOffset)};var co={};co.configure=function(e,t){let n=t.colouredLayout;return e.layout&&(n=t.layout(e.layout.type,e.layout)),function(e,t){return n=>{process.stderr.write(`${e(n,t)}\n`)}}(n,e.timezoneOffset)};var ao={};ao.configure=function(e,t,n,r){const u=n(e.appender);return function(e,t,n,r){const u=r.getLevel(e),o=r.getLevel(t,r.FATAL);return e=>{const t=e.level;t.isGreaterThanOrEqualTo(u)&&t.isLessThanOrEqualTo(o)&&n(e)}}(e.level,e.maxLevel,u,r)};var lo={};const fo=Nr.exports("log4js:categoryFilter");lo.configure=function(e,t,n){const r=n(e.appender);return function(e,t){return"string"==typeof e&&(e=[e]),n=>{fo(`Checking ${n.categoryName} against ${e}`),-1===e.indexOf(n.categoryName)&&(fo("Not excluded, sending to appender"),t(n))}}(e.exclude,r)};var Do={};const po=Nr.exports("log4js:noLogFilter");Do.configure=function(e,t,n){const r=n(e.appender);return function(e,t){return n=>{po(`Checking data: ${n.data} against filters: ${e}`),"string"==typeof e&&(e=[e]),e=e.filter((e=>null!=e&&""!==e));const r=new RegExp(e.join("|"),"i");(0===e.length||n.data.findIndex((e=>r.test(e)))<0)&&(po("Not excluded, sending to appender"),t(n))}}(e.exclude,r)};var Eo={},mo={exports:{}},ho={},yo={fromCallback:function(e){return Object.defineProperty((function(){if("function"!=typeof arguments[arguments.length-1])return new Promise(((t,n)=>{arguments[arguments.length]=(e,r)=>{if(e)return n(e);t(r)},arguments.length++,e.apply(this,arguments)}));e.apply(this,arguments)}),"name",{value:e.name})},fromPromise:function(e){return Object.defineProperty((function(){const t=arguments[arguments.length-1];if("function"!=typeof t)return e.apply(this,arguments);e.apply(this,arguments).then((e=>t(null,e)),t)}),"name",{value:e.name})}};!function(e){const t=yo.fromCallback,n=we,r=["access","appendFile","chmod","chown","close","copyFile","fchmod","fchown","fdatasync","fstat","fsync","ftruncate","futimes","lchown","lchmod","link","lstat","mkdir","mkdtemp","open","readFile","readdir","readlink","realpath","rename","rmdir","stat","symlink","truncate","unlink","utimes","writeFile"].filter((e=>"function"==typeof n[e]));Object.keys(n).forEach((t=>{"promises"!==t&&(e[t]=n[t])})),r.forEach((r=>{e[r]=t(n[r])})),e.exists=function(e,t){return"function"==typeof t?n.exists(e,t):new Promise((t=>n.exists(e,t)))},e.read=function(e,t,r,u,o,i){return"function"==typeof i?n.read(e,t,r,u,o,i):new Promise(((i,s)=>{n.read(e,t,r,u,o,((e,t,n)=>{if(e)return s(e);i({bytesRead:t,buffer:n})}))}))},e.write=function(e,t,...r){return"function"==typeof r[r.length-1]?n.write(e,t,...r):new Promise(((u,o)=>{n.write(e,t,...r,((e,t,n)=>{if(e)return o(e);u({bytesWritten:t,buffer:n})}))}))},"function"==typeof n.realpath.native&&(e.realpath.native=t(n.realpath.native))}(ho);const Co=p.default;function Fo(e){return(e=Co.normalize(Co.resolve(e)).split(Co.sep)).length>0?e[0]:null}const go=/[<>:"|?*]/;var Ao=function(e){const t=Fo(e);return e=e.replace(t,""),go.test(e)};const vo=we,So=p.default,wo=Ao,Oo=parseInt("0777",8);var bo=function e(t,n,r,u){if("function"==typeof n?(r=n,n={}):n&&"object"==typeof n||(n={mode:n}),"win32"===process.platform&&wo(t)){const e=new Error(t+" contains invalid WIN32 path characters.");return e.code="EINVAL",r(e)}let o=n.mode;const i=n.fs||vo;void 0===o&&(o=Oo&~process.umask()),u||(u=null),r=r||function(){},t=So.resolve(t),i.mkdir(t,o,(o=>{if(!o)return r(null,u=u||t);if("ENOENT"===o.code){if(So.dirname(t)===t)return r(o);e(So.dirname(t),n,((u,o)=>{u?r(u,o):e(t,n,r,o)}))}else i.stat(t,((e,t)=>{e||!t.isDirectory()?r(o,u):r(null,u)}))}))};const _o=we,Bo=p.default,Po=Ao,ko=parseInt("0777",8);var xo=function e(t,n,r){n&&"object"==typeof n||(n={mode:n});let u=n.mode;const o=n.fs||_o;if("win32"===process.platform&&Po(t)){const e=new Error(t+" contains invalid WIN32 path characters.");throw e.code="EINVAL",e}void 0===u&&(u=ko&~process.umask()),r||(r=null),t=Bo.resolve(t);try{o.mkdirSync(t,u),r=r||t}catch(u){if("ENOENT"===u.code){if(Bo.dirname(t)===t)throw u;r=e(Bo.dirname(t),n,r),e(t,n,r)}else{let e;try{e=o.statSync(t)}catch(e){throw u}if(!e.isDirectory())throw u}}return r};const No=(0,yo.fromCallback)(bo);var Io={mkdirs:No,mkdirsSync:xo,mkdirp:No,mkdirpSync:xo,ensureDir:No,ensureDirSync:xo};const To=we;E.default,p.default;var Ro=function(e,t,n,r){To.open(e,"r+",((e,u)=>{if(e)return r(e);To.futimes(u,t,n,(e=>{To.close(u,(t=>{r&&r(e||t)}))}))}))},Mo=function(e,t,n){const r=To.openSync(e,"r+");return To.futimesSync(r,t,n),To.closeSync(r)};const Lo=we,jo=p.default,$o=10,Ho=5,Jo=0,Go=process.versions.node.split("."),Vo=Number.parseInt(Go[0],10),Uo=Number.parseInt(Go[1],10),Wo=Number.parseInt(Go[2],10);function zo(){if(Vo>$o)return!0;if(Vo===$o){if(Uo>Ho)return!0;if(Uo===Ho&&Wo>=Jo)return!0}return!1}function Ko(e,t){const n=jo.resolve(e).split(jo.sep).filter((e=>e)),r=jo.resolve(t).split(jo.sep).filter((e=>e));return n.reduce(((e,t,n)=>e&&r[n]===t),!0)}function qo(e,t,n){return`Cannot ${n} '${e}' to a subdirectory of itself, '${t}'.`}var Yo,Xo,Zo={checkPaths:function(e,t,n,r){!function(e,t,n){zo()?Lo.stat(e,{bigint:!0},((e,r)=>{if(e)return n(e);Lo.stat(t,{bigint:!0},((e,t)=>e?"ENOENT"===e.code?n(null,{srcStat:r,destStat:null}):n(e):n(null,{srcStat:r,destStat:t})))})):Lo.stat(e,((e,r)=>{if(e)return n(e);Lo.stat(t,((e,t)=>e?"ENOENT"===e.code?n(null,{srcStat:r,destStat:null}):n(e):n(null,{srcStat:r,destStat:t})))}))}(e,t,((u,o)=>{if(u)return r(u);const{srcStat:i,destStat:s}=o;return s&&s.ino&&s.dev&&s.ino===i.ino&&s.dev===i.dev?r(new Error("Source and destination must not be the same.")):i.isDirectory()&&Ko(e,t)?r(new Error(qo(e,t,n))):r(null,{srcStat:i,destStat:s})}))},checkPathsSync:function(e,t,n){const{srcStat:r,destStat:u}=function(e,t){let n,r;n=zo()?Lo.statSync(e,{bigint:!0}):Lo.statSync(e);try{r=zo()?Lo.statSync(t,{bigint:!0}):Lo.statSync(t)}catch(e){if("ENOENT"===e.code)return{srcStat:n,destStat:null};throw e}return{srcStat:n,destStat:r}}(e,t);if(u&&u.ino&&u.dev&&u.ino===r.ino&&u.dev===r.dev)throw new Error("Source and destination must not be the same.");if(r.isDirectory()&&Ko(e,t))throw new Error(qo(e,t,n));return{srcStat:r,destStat:u}},checkParentPaths:function e(t,n,r,u,o){const i=jo.resolve(jo.dirname(t)),s=jo.resolve(jo.dirname(r));if(s===i||s===jo.parse(s).root)return o();zo()?Lo.stat(s,{bigint:!0},((i,c)=>i?"ENOENT"===i.code?o():o(i):c.ino&&c.dev&&c.ino===n.ino&&c.dev===n.dev?o(new Error(qo(t,r,u))):e(t,n,s,u,o))):Lo.stat(s,((i,c)=>i?"ENOENT"===i.code?o():o(i):c.ino&&c.dev&&c.ino===n.ino&&c.dev===n.dev?o(new Error(qo(t,r,u))):e(t,n,s,u,o)))},checkParentPathsSync:function e(t,n,r,u){const o=jo.resolve(jo.dirname(t)),i=jo.resolve(jo.dirname(r));if(i===o||i===jo.parse(i).root)return;let s;try{s=zo()?Lo.statSync(i,{bigint:!0}):Lo.statSync(i)}catch(e){if("ENOENT"===e.code)return;throw e}if(s.ino&&s.dev&&s.ino===n.ino&&s.dev===n.dev)throw new Error(qo(t,r,u));return e(t,n,i,u)},isSrcSubdir:Ko};const Qo=we,ei=p.default,ti=Io.mkdirsSync,ni=Mo,ri=Zo;function ui(e,t,n,r){if(!r.filter||r.filter(t,n))return function(e,t,n,r){const u=r.dereference?Qo.statSync:Qo.lstatSync,o=u(t);if(o.isDirectory())return function(e,t,n,r,u){if(!t)return function(e,t,n,r){return Qo.mkdirSync(n),ii(t,n,r),Qo.chmodSync(n,e.mode)}(e,n,r,u);if(t&&!t.isDirectory())throw new Error(`Cannot overwrite non-directory '${r}' with directory '${n}'.`);return ii(n,r,u)}(o,e,t,n,r);if(o.isFile()||o.isCharacterDevice()||o.isBlockDevice())return function(e,t,n,r,u){return t?function(e,t,n,r){if(r.overwrite)return Qo.unlinkSync(n),oi(e,t,n,r);if(r.errorOnExist)throw new Error(`'${n}' already exists`)}(e,n,r,u):oi(e,n,r,u)}(o,e,t,n,r);if(o.isSymbolicLink())return function(e,t,n,r){let u=Qo.readlinkSync(t);r.dereference&&(u=ei.resolve(process.cwd(),u));if(e){let e;try{e=Qo.readlinkSync(n)}catch(e){if("EINVAL"===e.code||"UNKNOWN"===e.code)return Qo.symlinkSync(u,n);throw e}if(r.dereference&&(e=ei.resolve(process.cwd(),e)),ri.isSrcSubdir(u,e))throw new Error(`Cannot copy '${u}' to a subdirectory of itself, '${e}'.`);if(Qo.statSync(n).isDirectory()&&ri.isSrcSubdir(e,u))throw new Error(`Cannot overwrite '${e}' with '${u}'.`);return function(e,t){return Qo.unlinkSync(t),Qo.symlinkSync(e,t)}(u,n)}return Qo.symlinkSync(u,n)}(e,t,n,r)}(e,t,n,r)}function oi(e,t,n,r){return"function"==typeof Qo.copyFileSync?(Qo.copyFileSync(t,n),Qo.chmodSync(n,e.mode),r.preserveTimestamps?ni(n,e.atime,e.mtime):void 0):function(e,t,n,r){const u=65536,o=(Xo?Yo:(Xo=1,Yo=function(e){if("function"==typeof Buffer.allocUnsafe)try{return Buffer.allocUnsafe(e)}catch(t){return new Buffer(e)}return new Buffer(e)}))(u),i=Qo.openSync(t,"r"),s=Qo.openSync(n,"w",e.mode);let c=0;for(;cfunction(e,t,n,r){const u=ei.join(t,e),o=ei.join(n,e),{destStat:i}=ri.checkPathsSync(u,o,"copy");return ui(i,u,o,r)}(r,e,t,n)))}var si=function(e,t,n){"function"==typeof n&&(n={filter:n}),(n=n||{}).clobber=!("clobber"in n)||!!n.clobber,n.overwrite="overwrite"in n?!!n.overwrite:n.clobber,n.preserveTimestamps&&"ia32"===process.arch&&console.warn("fs-extra: Using the preserveTimestamps option in 32-bit node is not recommended;\n\n see https://github.com/jprichardson/node-fs-extra/issues/269");const{srcStat:r,destStat:u}=ri.checkPathsSync(e,t,"copy");return ri.checkParentPathsSync(e,r,t,"copy"),function(e,t,n,r){if(r.filter&&!r.filter(t,n))return;const u=ei.dirname(n);Qo.existsSync(u)||ti(u);return ui(e,t,n,r)}(u,e,t,n)},ci={copySync:si};const ai=yo.fromPromise,li=ho;var fi={pathExists:ai((function(e){return li.access(e).then((()=>!0)).catch((()=>!1))})),pathExistsSync:li.existsSync};const di=we,Di=p.default,pi=Io.mkdirs,Ei=fi.pathExists,mi=Ro,hi=Zo;function yi(e,t,n,r,u){const o=Di.dirname(n);Ei(o,((i,s)=>i?u(i):s?Fi(e,t,n,r,u):void pi(o,(o=>o?u(o):Fi(e,t,n,r,u)))))}function Ci(e,t,n,r,u,o){Promise.resolve(u.filter(n,r)).then((i=>i?e(t,n,r,u,o):o()),(e=>o(e)))}function Fi(e,t,n,r,u){return r.filter?Ci(gi,e,t,n,r,u):gi(e,t,n,r,u)}function gi(e,t,n,r,u){(r.dereference?di.stat:di.lstat)(t,((o,i)=>o?u(o):i.isDirectory()?function(e,t,n,r,u,o){if(!t)return function(e,t,n,r,u){di.mkdir(n,(o=>{if(o)return u(o);Si(t,n,r,(t=>t?u(t):di.chmod(n,e.mode,u)))}))}(e,n,r,u,o);if(t&&!t.isDirectory())return o(new Error(`Cannot overwrite non-directory '${r}' with directory '${n}'.`));return Si(n,r,u,o)}(i,e,t,n,r,u):i.isFile()||i.isCharacterDevice()||i.isBlockDevice()?function(e,t,n,r,u,o){return t?function(e,t,n,r,u){if(!r.overwrite)return r.errorOnExist?u(new Error(`'${n}' already exists`)):u();di.unlink(n,(o=>o?u(o):Ai(e,t,n,r,u)))}(e,n,r,u,o):Ai(e,n,r,u,o)}(i,e,t,n,r,u):i.isSymbolicLink()?function(e,t,n,r,u){di.readlink(t,((t,o)=>t?u(t):(r.dereference&&(o=Di.resolve(process.cwd(),o)),e?void di.readlink(n,((t,i)=>t?"EINVAL"===t.code||"UNKNOWN"===t.code?di.symlink(o,n,u):u(t):(r.dereference&&(i=Di.resolve(process.cwd(),i)),hi.isSrcSubdir(o,i)?u(new Error(`Cannot copy '${o}' to a subdirectory of itself, '${i}'.`)):e.isDirectory()&&hi.isSrcSubdir(i,o)?u(new Error(`Cannot overwrite '${i}' with '${o}'.`)):function(e,t,n){di.unlink(t,(r=>r?n(r):di.symlink(e,t,n)))}(o,n,u)))):di.symlink(o,n,u))))}(e,t,n,r,u):void 0))}function Ai(e,t,n,r,u){return"function"==typeof di.copyFile?di.copyFile(t,n,(t=>t?u(t):vi(e,n,r,u))):function(e,t,n,r,u){const o=di.createReadStream(t);o.on("error",(e=>u(e))).once("open",(()=>{const t=di.createWriteStream(n,{mode:e.mode});t.on("error",(e=>u(e))).on("open",(()=>o.pipe(t))).once("close",(()=>vi(e,n,r,u)))}))}(e,t,n,r,u)}function vi(e,t,n,r){di.chmod(t,e.mode,(u=>u?r(u):n.preserveTimestamps?mi(t,e.atime,e.mtime,r):r()))}function Si(e,t,n,r){di.readdir(e,((u,o)=>u?r(u):wi(o,e,t,n,r)))}function wi(e,t,n,r,u){const o=e.pop();return o?function(e,t,n,r,u,o){const i=Di.join(n,t),s=Di.join(r,t);hi.checkPaths(i,s,"copy",((t,c)=>{if(t)return o(t);const{destStat:a}=c;Fi(a,i,s,u,(t=>t?o(t):wi(e,n,r,u,o)))}))}(e,o,t,n,r,u):u()}var Oi=function(e,t,n,r){"function"!=typeof n||r?"function"==typeof n&&(n={filter:n}):(r=n,n={}),r=r||function(){},(n=n||{}).clobber=!("clobber"in n)||!!n.clobber,n.overwrite="overwrite"in n?!!n.overwrite:n.clobber,n.preserveTimestamps&&"ia32"===process.arch&&console.warn("fs-extra: Using the preserveTimestamps option in 32-bit node is not recommended;\n\n see https://github.com/jprichardson/node-fs-extra/issues/269"),hi.checkPaths(e,t,"copy",((u,o)=>{if(u)return r(u);const{srcStat:i,destStat:s}=o;hi.checkParentPaths(e,i,t,"copy",(u=>u?r(u):n.filter?Ci(yi,s,e,t,n,r):yi(s,e,t,n,r)))}))};var bi={copy:(0,yo.fromCallback)(Oi)};const _i=we,Bi=p.default,Pi=g.default,ki="win32"===process.platform;function xi(e){["unlink","chmod","stat","lstat","rmdir","readdir"].forEach((t=>{e[t]=e[t]||_i[t],e[t+="Sync"]=e[t]||_i[t]})),e.maxBusyTries=e.maxBusyTries||3}function Ni(e,t,n){let r=0;"function"==typeof t&&(n=t,t={}),Pi(e,"rimraf: missing path"),Pi.strictEqual(typeof e,"string","rimraf: path should be a string"),Pi.strictEqual(typeof n,"function","rimraf: callback function required"),Pi(t,"rimraf: invalid options argument provided"),Pi.strictEqual(typeof t,"object","rimraf: options should be object"),xi(t),Ii(e,t,(function u(o){if(o){if(("EBUSY"===o.code||"ENOTEMPTY"===o.code||"EPERM"===o.code)&&rIi(e,t,u)),100*r)}"ENOENT"===o.code&&(o=null)}n(o)}))}function Ii(e,t,n){Pi(e),Pi(t),Pi("function"==typeof n),t.lstat(e,((r,u)=>r&&"ENOENT"===r.code?n(null):r&&"EPERM"===r.code&&ki?Ti(e,t,r,n):u&&u.isDirectory()?Mi(e,t,r,n):void t.unlink(e,(r=>{if(r){if("ENOENT"===r.code)return n(null);if("EPERM"===r.code)return ki?Ti(e,t,r,n):Mi(e,t,r,n);if("EISDIR"===r.code)return Mi(e,t,r,n)}return n(r)}))))}function Ti(e,t,n,r){Pi(e),Pi(t),Pi("function"==typeof r),n&&Pi(n instanceof Error),t.chmod(e,438,(u=>{u?r("ENOENT"===u.code?null:n):t.stat(e,((u,o)=>{u?r("ENOENT"===u.code?null:n):o.isDirectory()?Mi(e,t,n,r):t.unlink(e,r)}))}))}function Ri(e,t,n){let r;Pi(e),Pi(t),n&&Pi(n instanceof Error);try{t.chmodSync(e,438)}catch(e){if("ENOENT"===e.code)return;throw n}try{r=t.statSync(e)}catch(e){if("ENOENT"===e.code)return;throw n}r.isDirectory()?ji(e,t,n):t.unlinkSync(e)}function Mi(e,t,n,r){Pi(e),Pi(t),n&&Pi(n instanceof Error),Pi("function"==typeof r),t.rmdir(e,(u=>{!u||"ENOTEMPTY"!==u.code&&"EEXIST"!==u.code&&"EPERM"!==u.code?u&&"ENOTDIR"===u.code?r(n):r(u):function(e,t,n){Pi(e),Pi(t),Pi("function"==typeof n),t.readdir(e,((r,u)=>{if(r)return n(r);let o,i=u.length;if(0===i)return t.rmdir(e,n);u.forEach((r=>{Ni(Bi.join(e,r),t,(r=>{if(!o)return r?n(o=r):void(0==--i&&t.rmdir(e,n))}))}))}))}(e,t,r)}))}function Li(e,t){let n;xi(t=t||{}),Pi(e,"rimraf: missing path"),Pi.strictEqual(typeof e,"string","rimraf: path should be a string"),Pi(t,"rimraf: missing options"),Pi.strictEqual(typeof t,"object","rimraf: options should be object");try{n=t.lstatSync(e)}catch(n){if("ENOENT"===n.code)return;"EPERM"===n.code&&ki&&Ri(e,t,n)}try{n&&n.isDirectory()?ji(e,t,null):t.unlinkSync(e)}catch(n){if("ENOENT"===n.code)return;if("EPERM"===n.code)return ki?Ri(e,t,n):ji(e,t,n);if("EISDIR"!==n.code)throw n;ji(e,t,n)}}function ji(e,t,n){Pi(e),Pi(t),n&&Pi(n instanceof Error);try{t.rmdirSync(e)}catch(r){if("ENOTDIR"===r.code)throw n;if("ENOTEMPTY"===r.code||"EEXIST"===r.code||"EPERM"===r.code)!function(e,t){if(Pi(e),Pi(t),t.readdirSync(e).forEach((n=>Li(Bi.join(e,n),t))),!ki){return t.rmdirSync(e,t)}{const n=Date.now();do{try{return t.rmdirSync(e,t)}catch(e){}}while(Date.now()-n<500)}}(e,t);else if("ENOENT"!==r.code)throw r}}var $i=Ni;Ni.sync=Li;const Hi=$i;var Ji={remove:(0,yo.fromCallback)(Hi),removeSync:Hi.sync};const Gi=yo.fromCallback,Vi=we,Ui=p.default,Wi=Io,zi=Ji,Ki=Gi((function(e,t){t=t||function(){},Vi.readdir(e,((n,r)=>{if(n)return Wi.mkdirs(e,t);r=r.map((t=>Ui.join(e,t))),function e(){const n=r.pop();if(!n)return t();zi.remove(n,(n=>{if(n)return t(n);e()}))}()}))}));function qi(e){let t;try{t=Vi.readdirSync(e)}catch(t){return Wi.mkdirsSync(e)}t.forEach((t=>{t=Ui.join(e,t),zi.removeSync(t)}))}var Yi={emptyDirSync:qi,emptydirSync:qi,emptyDir:Ki,emptydir:Ki};const Xi=yo.fromCallback,Zi=p.default,Qi=we,es=Io,ts=fi.pathExists;var ns={createFile:Xi((function(e,t){function n(){Qi.writeFile(e,"",(e=>{if(e)return t(e);t()}))}Qi.stat(e,((r,u)=>{if(!r&&u.isFile())return t();const o=Zi.dirname(e);ts(o,((e,r)=>e?t(e):r?n():void es.mkdirs(o,(e=>{if(e)return t(e);n()}))))}))})),createFileSync:function(e){let t;try{t=Qi.statSync(e)}catch(e){}if(t&&t.isFile())return;const n=Zi.dirname(e);Qi.existsSync(n)||es.mkdirsSync(n),Qi.writeFileSync(e,"")}};const rs=yo.fromCallback,us=p.default,os=we,is=Io,ss=fi.pathExists;var cs={createLink:rs((function(e,t,n){function r(e,t){os.link(e,t,(e=>{if(e)return n(e);n(null)}))}ss(t,((u,o)=>u?n(u):o?n(null):void os.lstat(e,(u=>{if(u)return u.message=u.message.replace("lstat","ensureLink"),n(u);const o=us.dirname(t);ss(o,((u,i)=>u?n(u):i?r(e,t):void is.mkdirs(o,(u=>{if(u)return n(u);r(e,t)}))))}))))})),createLinkSync:function(e,t){if(os.existsSync(t))return;try{os.lstatSync(e)}catch(e){throw e.message=e.message.replace("lstat","ensureLink"),e}const n=us.dirname(t);return os.existsSync(n)||is.mkdirsSync(n),os.linkSync(e,t)}};const as=p.default,ls=we,fs=fi.pathExists;var ds={symlinkPaths:function(e,t,n){if(as.isAbsolute(e))return ls.lstat(e,(t=>t?(t.message=t.message.replace("lstat","ensureSymlink"),n(t)):n(null,{toCwd:e,toDst:e})));{const r=as.dirname(t),u=as.join(r,e);return fs(u,((t,o)=>t?n(t):o?n(null,{toCwd:u,toDst:e}):ls.lstat(e,(t=>t?(t.message=t.message.replace("lstat","ensureSymlink"),n(t)):n(null,{toCwd:e,toDst:as.relative(r,e)})))))}},symlinkPathsSync:function(e,t){let n;if(as.isAbsolute(e)){if(n=ls.existsSync(e),!n)throw new Error("absolute srcpath does not exist");return{toCwd:e,toDst:e}}{const r=as.dirname(t),u=as.join(r,e);if(n=ls.existsSync(u),n)return{toCwd:u,toDst:e};if(n=ls.existsSync(e),!n)throw new Error("relative srcpath does not exist");return{toCwd:e,toDst:as.relative(r,e)}}}};const Ds=we;var ps={symlinkType:function(e,t,n){if(n="function"==typeof t?t:n,t="function"!=typeof t&&t)return n(null,t);Ds.lstat(e,((e,r)=>{if(e)return n(null,"file");t=r&&r.isDirectory()?"dir":"file",n(null,t)}))},symlinkTypeSync:function(e,t){let n;if(t)return t;try{n=Ds.lstatSync(e)}catch(e){return"file"}return n&&n.isDirectory()?"dir":"file"}};const Es=yo.fromCallback,ms=p.default,hs=we,ys=Io.mkdirs,Cs=Io.mkdirsSync,Fs=ds.symlinkPaths,gs=ds.symlinkPathsSync,As=ps.symlinkType,vs=ps.symlinkTypeSync,Ss=fi.pathExists;var ws={createSymlink:Es((function(e,t,n,r){r="function"==typeof n?n:r,n="function"!=typeof n&&n,Ss(t,((u,o)=>u?r(u):o?r(null):void Fs(e,t,((u,o)=>{if(u)return r(u);e=o.toDst,As(o.toCwd,n,((n,u)=>{if(n)return r(n);const o=ms.dirname(t);Ss(o,((n,i)=>n?r(n):i?hs.symlink(e,t,u,r):void ys(o,(n=>{if(n)return r(n);hs.symlink(e,t,u,r)}))))}))}))))})),createSymlinkSync:function(e,t,n){if(hs.existsSync(t))return;const r=gs(e,t);e=r.toDst,n=vs(r.toCwd,n);const u=ms.dirname(t);return hs.existsSync(u)||Cs(u),hs.symlinkSync(e,t,n)}};var Os,bs={createFile:ns.createFile,createFileSync:ns.createFileSync,ensureFile:ns.createFile,ensureFileSync:ns.createFileSync,createLink:cs.createLink,createLinkSync:cs.createLinkSync,ensureLink:cs.createLink,ensureLinkSync:cs.createLinkSync,createSymlink:ws.createSymlink,createSymlinkSync:ws.createSymlinkSync,ensureSymlink:ws.createSymlink,ensureSymlinkSync:ws.createSymlinkSync};try{Os=we}catch(e){Os=D.default}function _s(e,t){var n,r="\n";return"object"==typeof t&&null!==t&&(t.spaces&&(n=t.spaces),t.EOL&&(r=t.EOL)),JSON.stringify(e,t?t.replacer:null,n).replace(/\n/g,r)+r}function Bs(e){return Buffer.isBuffer(e)&&(e=e.toString("utf8")),e=e.replace(/^\uFEFF/,"")}var Ps={readFile:function(e,t,n){null==n&&(n=t,t={}),"string"==typeof t&&(t={encoding:t});var r=(t=t||{}).fs||Os,u=!0;"throws"in t&&(u=t.throws),r.readFile(e,t,(function(r,o){if(r)return n(r);var i;o=Bs(o);try{i=JSON.parse(o,t?t.reviver:null)}catch(t){return u?(t.message=e+": "+t.message,n(t)):n(null,null)}n(null,i)}))},readFileSync:function(e,t){"string"==typeof(t=t||{})&&(t={encoding:t});var n=t.fs||Os,r=!0;"throws"in t&&(r=t.throws);try{var u=n.readFileSync(e,t);return u=Bs(u),JSON.parse(u,t.reviver)}catch(t){if(r)throw t.message=e+": "+t.message,t;return null}},writeFile:function(e,t,n,r){null==r&&(r=n,n={});var u=(n=n||{}).fs||Os,o="";try{o=_s(t,n)}catch(e){return void(r&&r(e,null))}u.writeFile(e,o,n,r)},writeFileSync:function(e,t,n){var r=(n=n||{}).fs||Os,u=_s(t,n);return r.writeFileSync(e,u,n)}},ks=Ps;const xs=yo.fromCallback,Ns=ks;var Is={readJson:xs(Ns.readFile),readJsonSync:Ns.readFileSync,writeJson:xs(Ns.writeFile),writeJsonSync:Ns.writeFileSync};const Ts=p.default,Rs=Io,Ms=fi.pathExists,Ls=Is;var js=function(e,t,n,r){"function"==typeof n&&(r=n,n={});const u=Ts.dirname(e);Ms(u,((o,i)=>o?r(o):i?Ls.writeJson(e,t,n,r):void Rs.mkdirs(u,(u=>{if(u)return r(u);Ls.writeJson(e,t,n,r)}))))};const $s=we,Hs=p.default,Js=Io,Gs=Is;var Vs=function(e,t,n){const r=Hs.dirname(e);$s.existsSync(r)||Js.mkdirsSync(r),Gs.writeJsonSync(e,t,n)};const Us=yo.fromCallback,Ws=Is;Ws.outputJson=Us(js),Ws.outputJsonSync=Vs,Ws.outputJSON=Ws.outputJson,Ws.outputJSONSync=Ws.outputJsonSync,Ws.writeJSON=Ws.writeJson,Ws.writeJSONSync=Ws.writeJsonSync,Ws.readJSON=Ws.readJson,Ws.readJSONSync=Ws.readJsonSync;var zs=Ws;const Ks=we,qs=p.default,Ys=ci.copySync,Xs=Ji.removeSync,Zs=Io.mkdirpSync,Qs=Zo;function ec(e,t,n){try{Ks.renameSync(e,t)}catch(r){if("EXDEV"!==r.code)throw r;return function(e,t,n){const r={overwrite:n,errorOnExist:!0};return Ys(e,t,r),Xs(e)}(e,t,n)}}var tc=function(e,t,n){const r=(n=n||{}).overwrite||n.clobber||!1,{srcStat:u}=Qs.checkPathsSync(e,t,"move");return Qs.checkParentPathsSync(e,u,t,"move"),Zs(qs.dirname(t)),function(e,t,n){if(n)return Xs(t),ec(e,t,n);if(Ks.existsSync(t))throw new Error("dest already exists.");return ec(e,t,n)}(e,t,r)},nc={moveSync:tc};const rc=we,uc=p.default,oc=bi.copy,ic=Ji.remove,sc=Io.mkdirp,cc=fi.pathExists,ac=Zo;function lc(e,t,n,r){rc.rename(e,t,(u=>u?"EXDEV"!==u.code?r(u):function(e,t,n,r){const u={overwrite:n,errorOnExist:!0};oc(e,t,u,(t=>t?r(t):ic(e,r)))}(e,t,n,r):r()))}var fc=function(e,t,n,r){"function"==typeof n&&(r=n,n={});const u=n.overwrite||n.clobber||!1;ac.checkPaths(e,t,"move",((n,o)=>{if(n)return r(n);const{srcStat:i}=o;ac.checkParentPaths(e,i,t,"move",(n=>{if(n)return r(n);sc(uc.dirname(t),(n=>n?r(n):function(e,t,n,r){if(n)return ic(t,(u=>u?r(u):lc(e,t,n,r)));cc(t,((u,o)=>u?r(u):o?r(new Error("dest already exists.")):lc(e,t,n,r)))}(e,t,u,r)))}))}))};var dc={move:(0,yo.fromCallback)(fc)};const Dc=yo.fromCallback,pc=we,Ec=p.default,mc=Io,hc=fi.pathExists;var yc={outputFile:Dc((function(e,t,n,r){"function"==typeof n&&(r=n,n="utf8");const u=Ec.dirname(e);hc(u,((o,i)=>o?r(o):i?pc.writeFile(e,t,n,r):void mc.mkdirs(u,(u=>{if(u)return r(u);pc.writeFile(e,t,n,r)}))))})),outputFileSync:function(e,...t){const n=Ec.dirname(e);if(pc.existsSync(n))return pc.writeFileSync(e,...t);mc.mkdirsSync(n),pc.writeFileSync(e,...t)}};!function(e){e.exports=Object.assign({},ho,ci,bi,Yi,bs,zs,Io,nc,dc,yc,fi,Ji);const t=D.default;Object.getOwnPropertyDescriptor(t,"promises")&&Object.defineProperty(e.exports,"promises",{get:()=>t.promises})}(mo);const Cc=Nr.exports("streamroller:fileNameFormatter"),Fc=p.default;const gc=Nr.exports("streamroller:fileNameParser"),Ac=nu.exports;const vc=Nr.exports("streamroller:moveAndMaybeCompressFile"),Sc=mo.exports,wc=v.default;var Oc=async(e,t,n)=>{if(n=function(e){const t={mode:parseInt("0600",8),compress:!1},n=Object.assign({},t,e);return vc(`_parseOption: moveAndMaybeCompressFile called with option=${JSON.stringify(n)}`),n}(n),e!==t){if(await Sc.pathExists(e))if(vc(`moveAndMaybeCompressFile: moving file from ${e} to ${t} ${n.compress?"with":"without"} compress`),n.compress)await new Promise(((r,u)=>{let o=!1;const i=Sc.createWriteStream(t,{mode:n.mode,flags:"wx"}).on("open",(()=>{o=!0;const t=Sc.createReadStream(e).on("open",(()=>{t.pipe(wc.createGzip()).pipe(i)})).on("error",(t=>{vc(`moveAndMaybeCompressFile: error reading ${e}`,t),i.destroy(t)}))})).on("finish",(()=>{vc(`moveAndMaybeCompressFile: finished compressing ${t}, deleting ${e}`),Sc.unlink(e).then(r).catch((t=>{vc(`moveAndMaybeCompressFile: error deleting ${e}, truncating instead`,t),Sc.truncate(e).then(r).catch((t=>{vc(`moveAndMaybeCompressFile: error truncating ${e}`,t),u(t)}))}))})).on("error",(e=>{o?(vc(`moveAndMaybeCompressFile: error writing ${t}, deleting`,e),Sc.unlink(t).then((()=>{u(e)})).catch((e=>{vc(`moveAndMaybeCompressFile: error deleting ${t}`,e),u(e)}))):(vc(`moveAndMaybeCompressFile: error creating ${t}`,e),u(e))}))})).catch((()=>{}));else{vc(`moveAndMaybeCompressFile: renaming ${e} to ${t}`);try{await Sc.move(e,t,{overwrite:!0})}catch(n){if(vc(`moveAndMaybeCompressFile: error renaming ${e} to ${t}`,n),"ENOENT"!==n.code){vc("moveAndMaybeCompressFile: trying copy+truncate instead");try{await Sc.copy(e,t,{overwrite:!0}),await Sc.truncate(e)}catch(e){vc("moveAndMaybeCompressFile: error copy+truncate",e)}}}}}else vc("moveAndMaybeCompressFile: source and target are the same, not doing anything")};const bc=Nr.exports("streamroller:RollingFileWriteStream"),_c=mo.exports,Bc=p.default,Pc=E.default,kc=()=>new Date,xc=nu.exports,{Writable:Nc}=C.default,Ic=({file:e,keepFileExt:t,needsIndex:n,alwaysIncludeDate:r,compress:u,fileNameSep:o})=>{let i=o||".";const s=Fc.join(e.dir,e.name),c=t=>t+e.ext,a=(e,t,r)=>!n&&r||!t?e:e+i+t,l=(e,t,n)=>(t>0||r)&&n?e+i+n:e,f=(e,t)=>t&&u?e+".gz":e,d=t?[l,a,c,f]:[c,l,a,f];return({date:e,index:t})=>(Cc(`_formatFileName: date=${e}, index=${t}`),d.reduce(((n,r)=>r(n,t,e)),s))},Tc=({file:e,keepFileExt:t,pattern:n,fileNameSep:r})=>{let u=r||".";const o="__NOT_MATCHING__";let i=[(e,t)=>e.endsWith(".gz")?(gc("it is gzipped"),t.isCompressed=!0,e.slice(0,-1*".gz".length)):e,t?t=>t.startsWith(e.name)&&t.endsWith(e.ext)?(gc("it starts and ends with the right things"),t.slice(e.name.length+1,-1*e.ext.length)):o:t=>t.startsWith(e.base)?(gc("it starts with the right things"),t.slice(e.base.length+1)):o,n?(e,t)=>{const r=e.split(u);let o=r[r.length-1];gc("items: ",r,", indexStr: ",o);let i=e;void 0!==o&&o.match(/^\d+$/)?(i=e.slice(0,-1*(o.length+1)),gc(`dateStr is ${i}`),n&&!i&&(i=o,o="0")):o="0";try{const r=Ac.parse(n,i,new Date(0,0));return Ac.asString(n,r)!==i?e:(t.index=parseInt(o,10),t.date=i,t.timestamp=r.getTime(),"")}catch(t){return gc(`Problem parsing ${i} as ${n}, error was: `,t),e}}:(e,t)=>e.match(/^\d+$/)?(gc("it has an index"),t.index=parseInt(e,10),""):e];return e=>{let t={filename:e,index:0,isCompressed:!1};return i.reduce(((e,n)=>n(e,t)),e)?null:t}},Rc=Oc;var Mc=class extends Nc{constructor(e,t){if(bc(`constructor: creating RollingFileWriteStream. path=${e}`),"string"!=typeof e||0===e.length)throw new Error(`Invalid filename: ${e}`);if(e.endsWith(Bc.sep))throw new Error(`Filename is a directory: ${e}`);0===e.indexOf(`~${Bc.sep}`)&&(e=e.replace("~",Pc.homedir())),super(t),this.options=this._parseOption(t),this.fileObject=Bc.parse(e),""===this.fileObject.dir&&(this.fileObject=Bc.parse(Bc.join(process.cwd(),e))),this.fileFormatter=Ic({file:this.fileObject,alwaysIncludeDate:this.options.alwaysIncludePattern,needsIndex:this.options.maxSize 0`)}else delete n.maxSize;if(n.numBackups||0===n.numBackups){if(n.numBackups<0)throw new Error(`options.numBackups (${n.numBackups}) should be >= 0`);if(n.numBackups>=Number.MAX_SAFE_INTEGER)throw new Error(`options.numBackups (${n.numBackups}) should be < Number.MAX_SAFE_INTEGER`);n.numToKeep=n.numBackups+1}else if(n.numToKeep<=0)throw new Error(`options.numToKeep (${n.numToKeep}) should be > 0`);return bc(`_parseOption: creating stream with option=${JSON.stringify(n)}`),n}_final(e){this.currentFileStream.end("",this.options.encoding,e)}_write(e,t,n){this._shouldRoll().then((()=>{bc(`_write: writing chunk. file=${this.currentFileStream.path} state=${JSON.stringify(this.state)} chunk=${e}`),this.currentFileStream.write(e,t,(t=>{this.state.currentSize+=e.length,n(t)}))}))}async _shouldRoll(){(this._dateChanged()||this._tooBig())&&(bc(`_shouldRoll: rolling because dateChanged? ${this._dateChanged()} or tooBig? ${this._tooBig()}`),await this._roll())}_dateChanged(){return this.state.currentDate&&this.state.currentDate!==xc(this.options.pattern,kc())}_tooBig(){return this.state.currentSize>=this.options.maxSize}_roll(){return bc("_roll: closing the current stream"),new Promise(((e,t)=>{this.currentFileStream.end("",this.options.encoding,(()=>{this._moveOldFiles().then(e).catch(t)}))}))}async _moveOldFiles(){const e=await this._getExistingFiles();for(let t=(this.state.currentDate?e.filter((e=>e.date===this.state.currentDate)):e).length;t>=0;t--){bc(`_moveOldFiles: i = ${t}`);const e=this.fileFormatter({date:this.state.currentDate,index:t}),n=this.fileFormatter({date:this.state.currentDate,index:t+1}),r={compress:this.options.compress&&0===t,mode:this.options.mode};await Rc(e,n,r)}this.state.currentSize=0,this.state.currentDate=this.state.currentDate?xc(this.options.pattern,kc()):null,bc(`_moveOldFiles: finished rolling files. state=${JSON.stringify(this.state)}`),this._renewWriteStream(),await new Promise(((e,t)=>{this.currentFileStream.write("","utf8",(()=>{this._clean().then(e).catch(t)}))}))}async _getExistingFiles(){const e=await _c.readdir(this.fileObject.dir).catch((()=>[]));bc(`_getExistingFiles: files=${e}`);const t=e.map((e=>this.fileNameParser(e))).filter((e=>e)),n=e=>(e.timestamp?e.timestamp:kc().getTime())-e.index;return t.sort(((e,t)=>n(e)-n(t))),t}_renewWriteStream(){const e=this.fileFormatter({date:this.state.currentDate,index:0}),t=e=>{try{return _c.mkdirSync(e,{recursive:!0})}catch(n){if("ENOENT"===n.code)return t(Bc.dirname(e)),t(e);if("EEXIST"!==n.code&&"EROFS"!==n.code)throw n;try{if(_c.statSync(e).isDirectory())return e;throw n}catch(e){throw n}}};t(this.fileObject.dir);const n={flags:this.options.flags,encoding:this.options.encoding,mode:this.options.mode};var r,u;_c.appendFileSync(e,"",(r={...n},u="flags",r["flag"]=r[u],delete r[u],r)),this.currentFileStream=_c.createWriteStream(e,n),this.currentFileStream.on("error",(e=>{this.emit("error",e)}))}async _clean(){const e=await this._getExistingFiles();if(bc(`_clean: numToKeep = ${this.options.numToKeep}, existingFiles = ${e.length}`),bc("_clean: existing files are: ",e),this._tooManyFiles(e.length)){const n=e.slice(0,e.length-this.options.numToKeep).map((e=>Bc.format({dir:this.fileObject.dir,base:e.filename})));await(t=n,bc(`deleteFiles: files to delete: ${t}`),Promise.all(t.map((e=>_c.unlink(e).catch((t=>{bc(`deleteFiles: error when unlinking ${e}, ignoring. Error was ${t}`)}))))))}var t}_tooManyFiles(e){return this.options.numToKeep>0&&e>this.options.numToKeep}};const Lc=Mc;var jc=class extends Lc{constructor(e,t,n,r){r||(r={}),t&&(r.maxSize=t),r.numBackups||0===r.numBackups||(n||0===n||(n=1),r.numBackups=n),super(e,r),this.backups=r.numBackups,this.size=this.options.maxSize}get theStream(){return this.currentFileStream}};const $c=Mc;var Hc={RollingFileWriteStream:Mc,RollingFileStream:jc,DateRollingFileStream:class extends $c{constructor(e,t,n){t&&"object"==typeof t&&(n=t,t=null),n||(n={}),t||(t="yyyy-MM-dd"),n.pattern=t,n.numBackups||0===n.numBackups?n.daysToKeep=n.numBackups:(n.daysToKeep||0===n.daysToKeep?process.emitWarning("options.daysToKeep is deprecated due to the confusion it causes when used together with file size rolling. Please use options.numBackups instead.","DeprecationWarning","streamroller-DEP0001"):n.daysToKeep=1,n.numBackups=n.daysToKeep),super(e,n),this.mode=this.options.mode}get theStream(){return this.currentFileStream}}};const Jc=Nr.exports("log4js:file"),Gc=p.default,Vc=Hc,Uc=E.default.EOL;let Wc=!1;const zc=new Set;function Kc(){zc.forEach((e=>{e.sighupHandler()}))}function qc(e,t,n,r){const u=new Vc.RollingFileStream(e,t,n,r);return u.on("error",(t=>{console.error("log4js.fileAppender - Writing to file %s, error happened ",e,t)})),u.on("drain",(()=>{process.emit("log4js:pause",!1)})),u}Eo.configure=function(e,t){let n=t.basicLayout;return e.layout&&(n=t.layout(e.layout.type,e.layout)),e.mode=e.mode||384,function(e,t,n,r,u,o){e=Gc.normalize(e),Jc("Creating file appender (",e,", ",n,", ",r=r||0===r?r:5,", ",u,", ",o,")");let i=qc(e,n,r,u);const s=function(e){if(i.writable){if(!0===u.removeColor){const t=/\x1b[[0-9;]*m/g;e.data=e.data.map((e=>"string"==typeof e?e.replace(t,""):e))}i.write(t(e,o)+Uc,"utf8")||process.emit("log4js:pause",!0)}};return s.reopen=function(){i.end((()=>{i=qc(e,n,r,u)}))},s.sighupHandler=function(){Jc("SIGHUP handler called."),s.reopen()},s.shutdown=function(e){zc.delete(s),0===zc.size&&Wc&&(process.removeListener("SIGHUP",Kc),Wc=!1),i.end("","utf-8",e)},zc.add(s),Wc||(process.on("SIGHUP",Kc),Wc=!0),s}(e.filename,n,e.maxLogSize,e.backups,e,e.timezoneOffset)};var Yc={};const Xc=Hc,Zc=E.default.EOL;function Qc(e,t,n,r,u){r.maxSize=r.maxLogSize;const o=function(e,t,n){const r=new Xc.DateRollingFileStream(e,t,n);return r.on("error",(t=>{console.error("log4js.dateFileAppender - Writing to file %s, error happened ",e,t)})),r.on("drain",(()=>{process.emit("log4js:pause",!1)})),r}(e,t,r),i=function(e){o.writable&&(o.write(n(e,u)+Zc,"utf8")||process.emit("log4js:pause",!0))};return i.shutdown=function(e){o.end("","utf-8",e)},i}Yc.configure=function(e,t){let n=t.basicLayout;return e.layout&&(n=t.layout(e.layout.type,e.layout)),e.alwaysIncludePattern||(e.alwaysIncludePattern=!1),e.mode=e.mode||384,Qc(e.filename,e.pattern,n,e,e.timezoneOffset)};var ea={};const ta=Nr.exports("log4js:fileSync"),na=p.default,ra=D.default,ua=E.default.EOL||"\n";function oa(e,t){if(ra.existsSync(e))return;const n=ra.openSync(e,t.flags,t.mode);ra.closeSync(n)}class ia{constructor(e,t,n,r){ta("In RollingFileStream"),function(){if(!e||!t||t<=0)throw new Error("You must specify a filename and file size")}(),this.filename=e,this.size=t,this.backups=n,this.options=r,this.currentSize=0,this.currentSize=function(e){let t=0;try{t=ra.statSync(e).size}catch(t){oa(e,r)}return t}(this.filename)}shouldRoll(){return ta("should roll with current size %d, and max size %d",this.currentSize,this.size),this.currentSize>=this.size}roll(e){const t=this,n=new RegExp(`^${na.basename(e)}`);function r(e){return n.test(e)}function u(t){return parseInt(t.substring(`${na.basename(e)}.`.length),10)||0}function o(e,t){return u(e)>u(t)?1:u(e) ${e}.${r+1}`),ra.renameSync(na.join(na.dirname(e),n),`${e}.${r+1}`)}}ta("Rolling, rolling, rolling"),ta("Renaming the old files"),ra.readdirSync(na.dirname(e)).filter(r).sort(o).reverse().forEach(i)}write(e,t){const n=this;ta("in write"),this.shouldRoll()&&(this.currentSize=0,this.roll(this.filename)),ta("writing the chunk to the file"),n.currentSize+=e.length,ra.appendFileSync(n.filename,e)}}ea.configure=function(e,t){let n=t.basicLayout;e.layout&&(n=t.layout(e.layout.type,e.layout));const r={flags:e.flags||"a",encoding:e.encoding||"utf8",mode:e.mode||384};return function(e,t,n,r,u,o){ta("fileSync appender created");const i=function(e,t,n){let r;var u;return t?r=new ia(e,t,n,o):(oa(u=e,o),r={write(e){ra.appendFileSync(u,e)}}),r}(e=na.normalize(e),n,r=r||0===r?r:5);return e=>{i.write(t(e,u)+ua)}}(e.filename,n,e.maxLogSize,e.backups,e.timezoneOffset,r)};var sa={};const ca=Nr.exports("log4js:tcp"),aa=S.default;sa.configure=function(e,t){ca(`configure with config = ${e}`);let n=function(e){return e.serialise()};return e.layout&&(n=t.layout(e.layout.type,e.layout)),function(e,t){let n=!1;const r=[];let u,o=3,i="__LOG4JS__";function s(e){ca("Writing log event to socket"),n=u.write(`${t(e)}${i}`,"utf8")}function c(){let e;for(ca("emptying buffer");e=r.shift();)s(e)}function a(e){n?s(e):(ca("buffering log event because it cannot write at the moment"),r.push(e))}return function t(){ca(`appender creating socket to ${e.host||"localhost"}:${e.port||5e3}`),i=`${e.endMsg||"__LOG4JS__"}`,u=aa.createConnection(e.port||5e3,e.host||"localhost"),u.on("connect",(()=>{ca("socket connected"),c(),n=!0})),u.on("drain",(()=>{ca("drain event received, emptying buffer"),n=!0,c()})),u.on("timeout",u.end.bind(u)),u.on("error",(e=>{ca("connection error",e),n=!1,c()})),u.on("close",t)}(),a.shutdown=function(e){ca("shutdown called"),r.length&&o?(ca("buffer has items, waiting 100ms to empty"),o-=1,setTimeout((()=>{a.shutdown(e)}),100)):(u.removeAllListeners("close"),u.end(e))},a}(e,n)};const la=p.default,fa=Nr.exports("log4js:appenders"),da=tu,Da=eo,pa=gu,Ea=hu,ma=to,ha=new Map;ha.set("console",oo),ha.set("stdout",so),ha.set("stderr",co),ha.set("logLevelFilter",ao),ha.set("categoryFilter",lo),ha.set("noLogFilter",Do),ha.set("file",Eo),ha.set("dateFile",Yc),ha.set("fileSync",ea),ha.set("tcp",sa);const ya=new Map,Ca=(e,t)=>{fa("Loading module from ",e);try{return require(e)}catch(n){return void da.throwExceptionIf(t,"MODULE_NOT_FOUND"!==n.code,`appender "${e}" could not be loaded (error was: ${n})`)}},Fa=new Set,ga=(e,t)=>{if(ya.has(e))return ya.get(e);if(!t.appenders[e])return!1;if(Fa.has(e))throw new Error(`Dependency loop detected for appender ${e}.`);Fa.add(e),fa(`Creating appender ${e}`);const n=Aa(e,t);return Fa.delete(e),ya.set(e,n),n},Aa=(e,t)=>{const n=t.appenders[e],r=n.type.configure?n.type:((e,t)=>ha.get(e)||Ca(`./${e}`,t)||Ca(e,t)||require.main&&Ca(la.join(la.dirname(require.main.filename),e),t)||Ca(la.join(process.cwd(),e),t))(n.type,t);return da.throwExceptionIf(t,da.not(r),`appender "${e}" is not valid (type "${n.type}" could not be found)`),r.appender&&fa(`DEPRECATION: Appender ${n.type} exports an appender function.`),r.shutdown&&fa(`DEPRECATION: Appender ${n.type} exports a shutdown function.`),fa(`${e}: clustering.isMaster ? ${Da.isMaster()}`),fa(`${e}: appenderModule is ${F.default.inspect(r)}`),Da.onlyOnMaster((()=>(fa(`calling appenderModule.configure for ${e} / ${n.type}`),r.configure(ma.modifyConfig(n),Ea,(e=>ga(e,t)),pa))),(()=>{}))},va=e=>{ya.clear(),Fa.clear();const t=[];Object.values(e.categories).forEach((e=>{t.push(...e.appenders)})),Object.keys(e.appenders).forEach((n=>{(t.includes(n)||"tcp-server"===e.appenders[n].type)&&ga(n,e)}))},Sa=()=>{va({appenders:{out:{type:"stdout"}},categories:{default:{appenders:["out"],level:"trace"}}})};Sa(),da.addListener((e=>{da.throwExceptionIf(e,da.not(da.anObject(e.appenders)),'must have a property "appenders" of type object.');const t=Object.keys(e.appenders);da.throwExceptionIf(e,da.not(t.length),"must define at least one appender."),t.forEach((t=>{da.throwExceptionIf(e,da.not(e.appenders[t].type),`appender "${t}" is not valid (must be an object with property "type")`)}))})),da.addListener(va),Au.exports=ya,Au.exports.init=Sa;var wa={exports:{}};!function(e){const t=Nr.exports("log4js:categories"),n=tu,r=gu,u=Au.exports,o=new Map;function i(e,t,n){if(!1===t.inherit)return;const r=n.lastIndexOf(".");if(r<0)return;const u=n.substring(0,r);let o=e.categories[u];o||(o={inherit:!0,appenders:[]}),i(e,o,u),!e.categories[u]&&o.appenders&&o.appenders.length&&o.level&&(e.categories[u]=o),t.appenders=t.appenders||[],t.level=t.level||o.level,o.appenders.forEach((e=>{t.appenders.includes(e)||t.appenders.push(e)})),t.parent=o}function s(e){if(!e.categories)return;Object.keys(e.categories).forEach((t=>{const n=e.categories[t];i(e,n,t)}))}n.addPreProcessingListener((e=>s(e))),n.addListener((e=>{n.throwExceptionIf(e,n.not(n.anObject(e.categories)),'must have a property "categories" of type object.');const t=Object.keys(e.categories);n.throwExceptionIf(e,n.not(t.length),"must define at least one category."),t.forEach((t=>{const o=e.categories[t];n.throwExceptionIf(e,[n.not(o.appenders),n.not(o.level)],`category "${t}" is not valid (must be an object with properties "appenders" and "level")`),n.throwExceptionIf(e,n.not(Array.isArray(o.appenders)),`category "${t}" is not valid (appenders must be an array of appender names)`),n.throwExceptionIf(e,n.not(o.appenders.length),`category "${t}" is not valid (appenders must contain at least one appender name)`),Object.prototype.hasOwnProperty.call(o,"enableCallStack")&&n.throwExceptionIf(e,"boolean"!=typeof o.enableCallStack,`category "${t}" is not valid (enableCallStack must be boolean type)`),o.appenders.forEach((r=>{n.throwExceptionIf(e,n.not(u.get(r)),`category "${t}" is not valid (appender "${r}" is not defined)`)})),n.throwExceptionIf(e,n.not(r.getLevel(o.level)),`category "${t}" is not valid (level "${o.level}" not recognised; valid levels are ${r.levels.join(", ")})`)})),n.throwExceptionIf(e,n.not(e.categories.default),'must define a "default" category.')}));const c=e=>{o.clear();Object.keys(e.categories).forEach((n=>{const i=e.categories[n],s=[];i.appenders.forEach((e=>{s.push(u.get(e)),t(`Creating category ${n}`),o.set(n,{appenders:s,level:r.getLevel(i.level),enableCallStack:i.enableCallStack||!1})}))}))},a=()=>{c({categories:{default:{appenders:["out"],level:"OFF"}}})};a(),n.addListener(c);const l=e=>(t(`configForCategory: searching for config for ${e}`),o.has(e)?(t(`configForCategory: ${e} exists in config, returning it`),o.get(e)):e.indexOf(".")>0?(t(`configForCategory: ${e} has hierarchy, searching for parents`),l(e.substring(0,e.lastIndexOf(".")))):(t("configForCategory: returning config for default category"),l("default")));e.exports=o,e.exports=Object.assign(e.exports,{appendersForCategory:e=>l(e).appenders,getLevelForCategory:e=>l(e).level,setLevelForCategory:(e,n)=>{let r=o.get(e);if(t(`setLevelForCategory: found ${r} for ${e}`),!r){const n=l(e);t(`setLevelForCategory: no config found for category, found ${n} for parents of ${e}`),r={appenders:n.appenders}}r.level=n,o.set(e,r)},getEnableCallStackForCategory:e=>!0===l(e).enableCallStack,setEnableCallStackForCategory:(e,t)=>{l(e).enableCallStack=t},init:a})}(wa);const Oa=Nr.exports("log4js:logger"),ba=Hu,_a=gu,Ba=eo,Pa=wa.exports,ka=tu,xa=/at (?:(.+)\s+\()?(?:(.+?):(\d+)(?::(\d+))?|([^)]+))\)?/;function Na(e,t=4){const n=e.stack.split("\n").slice(t),r=xa.exec(n[0]);return r&&6===r.length?{functionName:r[1],fileName:r[2],lineNumber:parseInt(r[3],10),columnNumber:parseInt(r[4],10),callStack:n.join("\n")}:null}class Ia{constructor(e){if(!e)throw new Error("No category provided.");this.category=e,this.context={},this.parseCallStack=Na,Oa(`Logger created (${this.category}, ${this.level})`)}get level(){return _a.getLevel(Pa.getLevelForCategory(this.category),_a.TRACE)}set level(e){Pa.setLevelForCategory(this.category,_a.getLevel(e,this.level))}get useCallStack(){return Pa.getEnableCallStackForCategory(this.category)}set useCallStack(e){Pa.setEnableCallStackForCategory(this.category,!0===e)}log(e,...t){let n=_a.getLevel(e);n||(this._log(_a.WARN,"log4js:logger.log: invalid value for log-level as first parameter given: ",e),n=_a.INFO),this.isLevelEnabled(n)&&this._log(n,t)}isLevelEnabled(e){return this.level.isLessThanOrEqualTo(e)}_log(e,t){Oa(`sending log data (${e}) to appenders`);const n=new ba(this.category,e,t,this.context,this.useCallStack&&this.parseCallStack(new Error));Ba.send(n)}addContext(e,t){this.context[e]=t}removeContext(e){delete this.context[e]}clearContext(){this.context={}}setParseCallStackFunction(e){this.parseCallStack=e}}function Ta(e){const t=_a.getLevel(e),n=t.toString().toLowerCase().replace(/_([a-z])/g,(e=>e[1].toUpperCase())),r=n[0].toUpperCase()+n.slice(1);Ia.prototype[`is${r}Enabled`]=function(){return this.isLevelEnabled(t)},Ia.prototype[n]=function(...e){this.log(t,...e)}}_a.levels.forEach(Ta),ka.addListener((()=>{_a.levels.forEach(Ta)}));var Ra=Ia;const Ma=gu;function La(e){return e.originalUrl||e.url}function ja(e,t){for(let n=0;ne.source?e.source:e));t=new RegExp(n.join("|"))}return t}(t.nolog);return(e,i,s)=>{if(e._logging)return s();if(o&&o.test(e.originalUrl))return s();if(n.isLevelEnabled(r)||"auto"===t.level){const o=new Date,{writeHead:s}=i;e._logging=!0,i.writeHead=(e,t)=>{i.writeHead=s,i.writeHead(e,t),i.__statusCode=e,i.__headers=t||{}},i.on("finish",(()=>{i.responseTime=new Date-o,i.statusCode&&"auto"===t.level&&(r=Ma.INFO,i.statusCode>=300&&(r=Ma.WARN),i.statusCode>=400&&(r=Ma.ERROR)),r=function(e,t,n){let r=t;if(n){const t=n.find((t=>{let n=!1;return n=t.from&&t.to?e>=t.from&&e<=t.to:-1!==t.codes.indexOf(e),n}));t&&(r=Ma.getLevel(t.level,r))}return r}(i.statusCode,r,t.statusRules);const s=function(e,t,n){const r=[];return r.push({token:":url",replacement:La(e)}),r.push({token:":protocol",replacement:e.protocol}),r.push({token:":hostname",replacement:e.hostname}),r.push({token:":method",replacement:e.method}),r.push({token:":status",replacement:t.__statusCode||t.statusCode}),r.push({token:":response-time",replacement:t.responseTime}),r.push({token:":date",replacement:(new Date).toUTCString()}),r.push({token:":referrer",replacement:e.headers.referer||e.headers.referrer||""}),r.push({token:":http-version",replacement:`${e.httpVersionMajor}.${e.httpVersionMinor}`}),r.push({token:":remote-addr",replacement:e.headers["x-forwarded-for"]||e.ip||e._remoteAddress||e.socket&&(e.socket.remoteAddress||e.socket.socket&&e.socket.socket.remoteAddress)}),r.push({token:":user-agent",replacement:e.headers["user-agent"]}),r.push({token:":content-length",replacement:t.getHeader("content-length")||t.__headers&&t.__headers["Content-Length"]||"-"}),r.push({token:/:req\[([^\]]+)]/g,replacement:(t,n)=>e.headers[n.toLowerCase()]}),r.push({token:/:res\[([^\]]+)]/g,replacement:(e,n)=>t.getHeader(n.toLowerCase())||t.__headers&&t.__headers[n]}),(e=>{const t=e.concat();for(let e=0;eja(e,s)));t&&n.log(r,t)}else n.log(r,ja(u,s));t.context&&n.removeContext("res")}))}return s()}},nl=Va;let rl=!1;function ul(e){if(!rl)return;Ua("Received log event ",e);Za.appendersForCategory(e.categoryName).forEach((t=>{t(e)}))}function ol(e){rl&&il();let t=e;return"string"==typeof t&&(t=function(e){Ua(`Loading configuration from ${e}`);try{return JSON.parse(Wa.readFileSync(e,"utf8"))}catch(t){throw new Error(`Problem reading config from file "${e}". Error was ${t.message}`,t)}}(e)),Ua(`Configuration is ${t}`),Ka.configure(za(t)),el.onMessage(ul),rl=!0,sl}function il(e){Ua("Shutdown called. Disabling all log writing."),rl=!1;const t=Array.from(Xa.values());Xa.init(),Za.init();const n=t.reduceRight(((e,t)=>t.shutdown?e+1:e),0);if(0===n)return Ua("No appenders with shutdown functions found."),void 0!==e&&e();let r,u=0;function o(t){r=r||t,u+=1,Ua(`Appender shutdowns complete: ${u} / ${n}`),u>=n&&(Ua("All shutdown functions completed."),e&&e(r))}return Ua(`Found ${n} appenders with shutdown functions.`),t.filter((e=>e.shutdown)).forEach((e=>e.shutdown(o))),null}const sl={getLogger:function(e){return rl||ol(process.env.LOG4JS_CONFIG||{appenders:{out:{type:"stdout"}},categories:{default:{appenders:["out"],level:"OFF"}}}),new Qa(e||"default")},configure:ol,shutdown:il,connectLogger:tl,levels:Ya,addLayout:qa.addLayout,recording:function(){return nl}};var cl=sl,al={};Object.defineProperty(al,"__esModule",{value:!0}),al.levelMap=al.getLevel=al.setCategoriesLevel=al.getConfiguration=al.setConfiguration=void 0;const ll=cl;let fl={appenders:{debug:{type:"stdout",layout:{type:"pattern",pattern:"[%d] > hvigor %p %c %[%m%]"}},info:{type:"stdout",layout:{type:"pattern",pattern:"[%d] > hvigor %[%m%]"}},"no-pattern-info":{type:"stdout",layout:{type:"pattern",pattern:"%m"}},wrong:{type:"stderr",layout:{type:"pattern",pattern:"[%d] > hvigor %[%p: %m%]"}},"just-debug":{type:"logLevelFilter",appender:"debug",level:"debug",maxLevel:"debug"},"just-info":{type:"logLevelFilter",appender:"info",level:"info",maxLevel:"info"},"just-wrong":{type:"logLevelFilter",appender:"wrong",level:"warn",maxLevel:"error"}},categories:{default:{appenders:["just-debug","just-info","just-wrong"],level:"debug"},"no-pattern-info":{appenders:["no-pattern-info"],level:"info"}}};al.setConfiguration=e=>{fl=e};al.getConfiguration=()=>fl;let dl=ll.levels.DEBUG;al.setCategoriesLevel=(e,t)=>{dl=e;const n=fl.categories;for(const r in n)(null==t?void 0:t.includes(r))||Object.prototype.hasOwnProperty.call(n,r)&&(n[r].level=e.levelStr)};al.getLevel=()=>dl,al.levelMap=new Map([["ALL",ll.levels.ALL],["MARK",ll.levels.MARK],["TRACE",ll.levels.TRACE],["DEBUG",ll.levels.DEBUG],["INFO",ll.levels.INFO],["WARN",ll.levels.WARN],["ERROR",ll.levels.ERROR],["FATAL",ll.levels.FATAL],["OFF",ll.levels.OFF]]);var Dl=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),pl=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),El=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)"default"!==n&&Object.prototype.hasOwnProperty.call(e,n)&&Dl(t,e,n);return pl(t,e),t};Object.defineProperty(xr,"__esModule",{value:!0}),xr.evaluateLogLevel=xr.HvigorLogger=void 0;const ml=El(cl),hl=cl,yl=El(F.default),Cl=al;class Fl{constructor(e){ml.configure((0,Cl.getConfiguration)()),this._logger=ml.getLogger(e),this._logger.level=(0,Cl.getLevel)()}static getLogger(e){return new Fl(e)}log(e,...t){this._logger.log(e,...t)}debug(e,...t){this._logger.debug(e,...t)}info(e,...t){this._logger.info(e,...t)}warn(e,...t){void 0!==e&&""!==e&&this._logger.warn(e,...t)}error(e,...t){this._logger.error(e,...t)}_printTaskExecuteInfo(e,t){this.info(`Finished :${e}... after ${t}`)}_printFailedTaskInfo(e){this.error(`Failed :${e}... `)}_printDisabledTaskInfo(e){this.info(`Disabled :${e}... `)}_printUpToDateTaskInfo(e){this.info(`UP-TO-DATE :${e}... `)}errorMessageExit(e,...t){throw new Error(yl.format(e,...t))}errorExit(e,t,...n){t&&this._logger.error(t,n),this._logger.error(e.stack)}setLevel(e,t){(0,Cl.setCategoriesLevel)(e,t),ml.shutdown(),ml.configure((0,Cl.getConfiguration)())}getLevel(){return this._logger.level}configure(e){const t=(0,Cl.getConfiguration)(),n={appenders:{...t.appenders,...e.appenders},categories:{...t.categories,...e.categories}};(0,Cl.setConfiguration)(n),ml.shutdown(),ml.configure(n)}}xr.HvigorLogger=Fl,xr.evaluateLogLevel=function(e,t){t.debug?e.setLevel(hl.levels.DEBUG):t.warn?e.setLevel(hl.levels.WARN):t.error?e.setLevel(hl.levels.ERROR):e.setLevel(hl.levels.INFO)};var gl=w&&w.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(X,"__esModule",{value:!0}),X.parseJsonText=X.parseJsonFile=void 0;const Al=Z,vl=gl(kr),Sl=gl(p.default),wl=gl(E.default),Ol=xr.HvigorLogger.getLogger("parse-json-util");var bl;!function(e){e[e.Char=0]="Char",e[e.EOF=1]="EOF",e[e.Identifier=2]="Identifier"}(bl||(bl={}));let _l,Bl,Pl,kl,xl,Nl,Il="start",Tl=[],Rl=0,Ml=1,Ll=0,jl=!1,$l="default",Hl="'",Jl=1;function Gl(e,t=!1){Bl=String(e),Il="start",Tl=[],Rl=0,Ml=1,Ll=0,kl=void 0,jl=t;do{_l=Vl(),Xl[Il]()}while("eof"!==_l.type);return kl}function Vl(){for($l="default",xl="",Hl="'",Jl=1;;){Nl=Ul();const e=zl[$l]();if(e)return e}}function Ul(){if(Bl[Rl])return String.fromCodePoint(Bl.codePointAt(Rl))}function Wl(){const e=Ul();return"\n"===e?(Ml++,Ll=0):e?Ll+=e.length:Ll++,e&&(Rl+=e.length),e}X.parseJsonFile=function(e,t=!1,n="utf-8"){const r=vl.default.readFileSync(Sl.default.resolve(e),{encoding:n});try{return Gl(r,t)}catch(t){if(t instanceof SyntaxError){const n=t.message.split("at");2===n.length&&Ol.errorMessageExit(`${n[0].trim()}${wl.default.EOL}\t at ${e}:${n[1].trim()}`)}Ol.errorMessageExit(`${e} is not in valid JSON/JSON5 format.`)}},X.parseJsonText=Gl;const zl={default(){switch(Nl){case"/":return Wl(),void($l="comment");case void 0:return Wl(),Kl("eof")}if(!Al.JudgeUtil.isIgnoreChar(Nl)&&!Al.JudgeUtil.isSpaceSeparator(Nl))return zl[Il]();Wl()},start(){$l="value"},beforePropertyName(){switch(Nl){case"$":case"_":return xl=Wl(),void($l="identifierName");case"\\":return Wl(),void($l="identifierNameStartEscape");case"}":return Kl("punctuator",Wl());case'"':case"'":return Hl=Nl,Wl(),void($l="string")}if(Al.JudgeUtil.isIdStartChar(Nl))return xl+=Wl(),void($l="identifierName");throw tf(bl.Char,Wl())},afterPropertyName(){if(":"===Nl)return Kl("punctuator",Wl());throw tf(bl.Char,Wl())},beforePropertyValue(){$l="value"},afterPropertyValue(){switch(Nl){case",":case"}":return Kl("punctuator",Wl())}throw tf(bl.Char,Wl())},beforeArrayValue(){if("]"===Nl)return Kl("punctuator",Wl());$l="value"},afterArrayValue(){switch(Nl){case",":case"]":return Kl("punctuator",Wl())}throw tf(bl.Char,Wl())},end(){throw tf(bl.Char,Wl())},comment(){switch(Nl){case"*":return Wl(),void($l="multiLineComment");case"/":return Wl(),void($l="singleLineComment")}throw tf(bl.Char,Wl())},multiLineComment(){switch(Nl){case"*":return Wl(),void($l="multiLineCommentAsterisk");case void 0:throw tf(bl.Char,Wl())}Wl()},multiLineCommentAsterisk(){switch(Nl){case"*":return void Wl();case"/":return Wl(),void($l="default");case void 0:throw tf(bl.Char,Wl())}Wl(),$l="multiLineComment"},singleLineComment(){switch(Nl){case"\n":case"\r":case"\u2028":case"\u2029":return Wl(),void($l="default");case void 0:return Wl(),Kl("eof")}Wl()},value(){switch(Nl){case"{":case"[":return Kl("punctuator",Wl());case"n":return Wl(),ql("ull"),Kl("null",null);case"t":return Wl(),ql("rue"),Kl("boolean",!0);case"f":return Wl(),ql("alse"),Kl("boolean",!1);case"-":case"+":return"-"===Wl()&&(Jl=-1),void($l="numerical");case".":case"0":case"I":case"N":return void($l="numerical");case'"':case"'":return Hl=Nl,Wl(),xl="",void($l="string")}if(void 0===Nl||!Al.JudgeUtil.isDigitWithoutZero(Nl))throw tf(bl.Char,Wl());$l="numerical"},numerical(){switch(Nl){case".":return xl=Wl(),void($l="decimalPointLeading");case"0":return xl=Wl(),void($l="zero");case"I":return Wl(),ql("nfinity"),Kl("numeric",Jl*(1/0));case"N":return Wl(),ql("aN"),Kl("numeric",NaN)}if(void 0!==Nl&&Al.JudgeUtil.isDigitWithoutZero(Nl))return xl=Wl(),void($l="decimalInteger");throw tf(bl.Char,Wl())},zero(){switch(Nl){case".":case"e":case"E":return void($l="decimal");case"x":case"X":return xl+=Wl(),void($l="hexadecimal")}return Kl("numeric",0)},decimalInteger(){switch(Nl){case".":case"e":case"E":return void($l="decimal")}if(!Al.JudgeUtil.isDigit(Nl))return Kl("numeric",Jl*Number(xl));xl+=Wl()},decimal(){switch(Nl){case".":xl+=Wl(),$l="decimalFraction";break;case"e":case"E":xl+=Wl(),$l="decimalExponent"}},decimalPointLeading(){if(Al.JudgeUtil.isDigit(Nl))return xl+=Wl(),void($l="decimalFraction");throw tf(bl.Char,Wl())},decimalFraction(){switch(Nl){case"e":case"E":return xl+=Wl(),void($l="decimalExponent")}if(!Al.JudgeUtil.isDigit(Nl))return Kl("numeric",Jl*Number(xl));xl+=Wl()},decimalExponent(){switch(Nl){case"+":case"-":return xl+=Wl(),void($l="decimalExponentSign")}if(Al.JudgeUtil.isDigit(Nl))return xl+=Wl(),void($l="decimalExponentInteger");throw tf(bl.Char,Wl())},decimalExponentSign(){if(Al.JudgeUtil.isDigit(Nl))return xl+=Wl(),void($l="decimalExponentInteger");throw tf(bl.Char,Wl())},decimalExponentInteger(){if(!Al.JudgeUtil.isDigit(Nl))return Kl("numeric",Jl*Number(xl));xl+=Wl()},hexadecimal(){if(Al.JudgeUtil.isHexDigit(Nl))return xl+=Wl(),void($l="hexadecimalInteger");throw tf(bl.Char,Wl())},hexadecimalInteger(){if(!Al.JudgeUtil.isHexDigit(Nl))return Kl("numeric",Jl*Number(xl));xl+=Wl()},identifierNameStartEscape(){if("u"!==Nl)throw tf(bl.Char,Wl());Wl();const e=Yl();switch(e){case"$":case"_":break;default:if(!Al.JudgeUtil.isIdStartChar(e))throw tf(bl.Identifier)}xl+=e,$l="identifierName"},identifierName(){switch(Nl){case"$":case"_":case"":case"":return void(xl+=Wl());case"\\":return Wl(),void($l="identifierNameEscape")}if(!Al.JudgeUtil.isIdContinueChar(Nl))return Kl("identifier",xl);xl+=Wl()},identifierNameEscape(){if("u"!==Nl)throw tf(bl.Char,Wl());Wl();const e=Yl();switch(e){case"$":case"_":case"":case"":break;default:if(!Al.JudgeUtil.isIdContinueChar(e))throw tf(bl.Identifier)}xl+=e,$l="identifierName"},string(){switch(Nl){case"\\":return Wl(),void(xl+=function(){const e=Ul(),t=function(){switch(Ul()){case"b":return Wl(),"\b";case"f":return Wl(),"\f";case"n":return Wl(),"\n";case"r":return Wl(),"\r";case"t":return Wl(),"\t";case"v":return Wl(),"\v"}return}();if(t)return t;switch(e){case"0":if(Wl(),Al.JudgeUtil.isDigit(Ul()))throw tf(bl.Char,Wl());return"\0";case"x":return Wl(),function(){let e="",t=Ul();if(!Al.JudgeUtil.isHexDigit(t))throw tf(bl.Char,Wl());if(e+=Wl(),t=Ul(),!Al.JudgeUtil.isHexDigit(t))throw tf(bl.Char,Wl());return e+=Wl(),String.fromCodePoint(parseInt(e,16))}();case"u":return Wl(),Yl();case"\n":case"\u2028":case"\u2029":return Wl(),"";case"\r":return Wl(),"\n"===Ul()&&Wl(),""}if(void 0===e||Al.JudgeUtil.isDigitWithoutZero(e))throw tf(bl.Char,Wl());return Wl()}());case'"':case"'":if(Nl===Hl){const e=Kl("string",xl);return Wl(),e}return void(xl+=Wl());case"\n":case"\r":case void 0:throw tf(bl.Char,Wl());case"\u2028":case"\u2029":!function(e){Ol.warn(`JSON5: '${ef(e)}' in strings is not valid ECMAScript; consider escaping.`)}(Nl)}xl+=Wl()}};function Kl(e,t){return{type:e,value:t,line:Ml,column:Ll}}function ql(e){for(const t of e){if(Ul()!==t)throw tf(bl.Char,Wl());Wl()}}function Yl(){let e="",t=4;for(;t-- >0;){const t=Ul();if(!Al.JudgeUtil.isHexDigit(t))throw tf(bl.Char,Wl());e+=Wl()}return String.fromCodePoint(parseInt(e,16))}const Xl={start(){if("eof"===_l.type)throw tf(bl.EOF);Zl()},beforePropertyName(){switch(_l.type){case"identifier":case"string":return Pl=_l.value,void(Il="afterPropertyName");case"punctuator":return void Ql();case"eof":throw tf(bl.EOF)}},afterPropertyName(){if("eof"===_l.type)throw tf(bl.EOF);Il="beforePropertyValue"},beforePropertyValue(){if("eof"===_l.type)throw tf(bl.EOF);Zl()},afterPropertyValue(){if("eof"===_l.type)throw tf(bl.EOF);switch(_l.value){case",":return void(Il="beforePropertyName");case"}":Ql()}},beforeArrayValue(){if("eof"===_l.type)throw tf(bl.EOF);"punctuator"!==_l.type||"]"!==_l.value?Zl():Ql()},afterArrayValue(){if("eof"===_l.type)throw tf(bl.EOF);switch(_l.value){case",":return void(Il="beforeArrayValue");case"]":Ql()}},end(){}};function Zl(){const e=function(){let e;switch(_l.type){case"punctuator":switch(_l.value){case"{":e={};break;case"[":e=[]}break;case"null":case"boolean":case"numeric":case"string":e=_l.value}return e}();if(jl&&"object"==typeof e&&(e._line=Ml,e._column=Ll),void 0===kl)kl=e;else{const t=Tl[Tl.length-1];Array.isArray(t)?jl&&"object"!=typeof e?t.push({value:e,_line:Ml,_column:Ll}):t.push(e):t[Pl]=jl&&"object"!=typeof e?{value:e,_line:Ml,_column:Ll}:e}!function(e){if(e&&"object"==typeof e)Tl.push(e),Il=Array.isArray(e)?"beforeArrayValue":"beforePropertyName";else{const e=Tl[Tl.length-1];Il=e?Array.isArray(e)?"afterArrayValue":"afterPropertyValue":"end"}}(e)}function Ql(){Tl.pop();const e=Tl[Tl.length-1];Il=e?Array.isArray(e)?"afterArrayValue":"afterPropertyValue":"end"}function ef(e){const t={"'":"\\'",'"':'\\"',"\\":"\\\\","\b":"\\b","\f":"\\f","\n":"\\n","\r":"\\r","\t":"\\t","\v":"\\v","\0":"\\0","\u2028":"\\u2028","\u2029":"\\u2029"};if(t[e])return t[e];if(e<" "){const t=e.charCodeAt(0).toString(16);return`\\x${`00${t}`.substring(t.length)}`}return e}function tf(e,t){let n="";switch(e){case bl.Char:n=void 0===t?`JSON5: invalid end of input at ${Ml}:${Ll}`:`JSON5: invalid character '${ef(t)}' at ${Ml}:${Ll}`;break;case bl.EOF:n=`JSON5: invalid end of input at ${Ml}:${Ll}`;break;case bl.Identifier:Ll-=5,n=`JSON5: invalid identifier character at ${Ml}:${Ll}`}const r=new nf(n);return r.lineNumber=Ml,r.columnNumber=Ll,r}class nf extends SyntaxError{}var rf=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),uf=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),of=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)"default"!==n&&Object.prototype.hasOwnProperty.call(e,n)&&rf(t,e,n);return uf(t,e),t};Object.defineProperty(Y,"__esModule",{value:!0});var sf=Y.cleanWorkSpace=Ff=Y.executeInstallHvigor=yf=Y.isHvigorInstalled=mf=Y.isAllDependenciesInstalled=void 0;const cf=of(D.default),af=of(p.default),lf=b,ff=j,df=$,Df=X;let pf,Ef;var mf=Y.isAllDependenciesInstalled=function(){function e(e){const t=null==e?void 0:e.dependencies;return void 0===t?0:Object.getOwnPropertyNames(t).length}if(pf=gf(),Ef=Af(),e(pf)+1!==e(Ef))return!1;for(const e in null==pf?void 0:pf.dependencies)if(!(0,ff.hasNpmPackInPaths)(e,[lf.HVIGOR_PROJECT_DEPENDENCIES_HOME])||!hf(e,pf,Ef))return!1;return!0};function hf(e,t,n){return void 0!==n.dependencies&&(0,ff.offlinePluginConversion)(lf.HVIGOR_PROJECT_ROOT_DIR,t.dependencies[e])===n.dependencies[e]}var yf=Y.isHvigorInstalled=function(){return pf=gf(),Ef=Af(),(0,ff.hasNpmPackInPaths)(lf.HVIGOR_ENGINE_PACKAGE_NAME,[lf.HVIGOR_PROJECT_DEPENDENCIES_HOME])&&(0,ff.offlinePluginConversion)(lf.HVIGOR_PROJECT_ROOT_DIR,pf.hvigorVersion)===Ef.dependencies[lf.HVIGOR_ENGINE_PACKAGE_NAME]};const Cf={cwd:lf.HVIGOR_PROJECT_DEPENDENCIES_HOME,stdio:["inherit","inherit","inherit"]};var Ff=Y.executeInstallHvigor=function(){(0,df.logInfoPrintConsole)("Hvigor installing...");const e={dependencies:{}};e.dependencies[lf.HVIGOR_ENGINE_PACKAGE_NAME]=(0,ff.offlinePluginConversion)(lf.HVIGOR_PROJECT_ROOT_DIR,pf.hvigorVersion);try{cf.mkdirSync(lf.HVIGOR_PROJECT_DEPENDENCIES_HOME,{recursive:!0});const t=af.resolve(lf.HVIGOR_PROJECT_DEPENDENCIES_HOME,lf.DEFAULT_PACKAGE_JSON);cf.writeFileSync(t,JSON.stringify(e))}catch(e){(0,df.logErrorAndExit)(e)}!function(){const e=["config","set","store-dir",lf.HVIGOR_PNPM_STORE_PATH];(0,ff.executeCommand)(lf.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH,e,Cf)}(),(0,ff.executeCommand)(lf.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH,["install"],Cf)};function gf(){const e=af.resolve(lf.HVIGOR_PROJECT_WRAPPER_HOME,lf.DEFAULT_HVIGOR_CONFIG_JSON_FILE_NAME);return cf.existsSync(e)||(0,df.logErrorAndExit)(`Error: Hvigor config file ${e} does not exist.`),(0,Df.parseJsonFile)(e)}function Af(){return cf.existsSync(lf.HVIGOR_PROJECT_DEPENDENCY_PACKAGE_JSON_PATH)?(0,Df.parseJsonFile)(lf.HVIGOR_PROJECT_DEPENDENCY_PACKAGE_JSON_PATH):{dependencies:{}}}sf=Y.cleanWorkSpace=function(){if((0,df.logInfoPrintConsole)("Hvigor cleaning..."),!cf.existsSync(lf.HVIGOR_PROJECT_DEPENDENCIES_HOME))return;const e=cf.readdirSync(lf.HVIGOR_PROJECT_DEPENDENCIES_HOME);if(e&&0!==e.length){cf.existsSync(lf.HVIGOR_BOOT_JS_FILE_PATH)&&(0,ff.executeCommand)(process.argv[0],[lf.HVIGOR_BOOT_JS_FILE_PATH,"--stop-daemon"],{});try{e.forEach((e=>{cf.rmSync(af.resolve(lf.HVIGOR_PROJECT_DEPENDENCIES_HOME,e),{recursive:!0})}))}catch(e){(0,df.logErrorAndExit)(`The hvigor build tool cannot be installed. Please manually clear the workspace directory and synchronize the project again.\n\n Workspace Path: ${lf.HVIGOR_PROJECT_DEPENDENCIES_HOME}.`)}}};var vf={},Sf=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),wf=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),Of=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)"default"!==n&&Object.prototype.hasOwnProperty.call(e,n)&&Sf(t,e,n);return wf(t,e),t};Object.defineProperty(vf,"__esModule",{value:!0});var bf=vf.executeBuild=void 0;const _f=b,Bf=Of(D.default),Pf=Of(p.default),kf=$;bf=vf.executeBuild=function(){const e=Pf.resolve(_f.HVIGOR_PROJECT_DEPENDENCIES_HOME,"node_modules","@ohos","hvigor","bin","hvigor.js");try{const t=Bf.realpathSync(e);require(t)}catch(t){(0,kf.logErrorAndExit)(`Error: ENOENT: no such file ${e},delete ${_f.HVIGOR_PROJECT_DEPENDENCIES_HOME} and retry.`)}},function(){if(O.checkNpmConifg(),O.environmentHandler(),O.isPnpmAvailable()||O.executeInstallPnpm(),yf()&&mf())bf();else{sf();try{Ff()}catch(e){return void sf()}bf()}}();
\ No newline at end of file
diff --git a/storage/storagefilejstest/hvigorfile.ts b/storage/storagefilejstest/hvigorfile.ts
deleted file mode 100644
index 3b846507adfe4a668350cbc3a965448a2bf02ff0..0000000000000000000000000000000000000000
--- a/storage/storagefilejstest/hvigorfile.ts
+++ /dev/null
@@ -1,17 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-// Script for compiling build behavior. It is built in the build plug-in and cannot be modified currently.
-export { legacyAppTasks } from '@ohos/hvigor-ohos-plugin';
\ No newline at end of file
diff --git a/storage/storagefilejstest/hvigorw b/storage/storagefilejstest/hvigorw
deleted file mode 100755
index b4d7760e72934718fc616fcef2806a1c7f04ba34..0000000000000000000000000000000000000000
--- a/storage/storagefilejstest/hvigorw
+++ /dev/null
@@ -1,61 +0,0 @@
-# Copyright (c) 2023 Huawei Device Co., Ltd.
-# Licensed under the Apache License, Version 2.0 (the "License");
-# you may not use this file except in compliance with the License.
-# You may obtain a copy of the License at
-#
-# http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-
-#!/bin/bash
-
-# ----------------------------------------------------------------------------
-# Hvigor startup script, version 1.0.0
-#
-# Required ENV vars:
-# ------------------
-# NODE_HOME - location of a Node home dir
-# or
-# Add /usr/local/nodejs/bin to the PATH environment variable
-# ----------------------------------------------------------------------------
-
-HVIGOR_APP_HOME=$(dirname $(readlink -f $0))
-HVIGOR_WRAPPER_SCRIPT=${HVIGOR_APP_HOME}/hvigor/hvigor-wrapper.js
-warn() {
- echo ""
- echo -e "\033[1;33m`date '+[%Y-%m-%d %H:%M:%S]'`$@\033[0m"
-}
-
-error() {
- echo ""
- echo -e "\033[1;31m`date '+[%Y-%m-%d %H:%M:%S]'`$@\033[0m"
-}
-
-fail() {
- error "$@"
- exit 1
-}
-
-# Determine node to start hvigor wrapper script
-if [ -n "${NODE_HOME}" ];then
- EXECUTABLE_NODE="${NODE_HOME}/bin/node"
- if [ ! -x "$EXECUTABLE_NODE" ];then
- fail "ERROR: NODE_HOME is set to an invalid directory,check $NODE_HOME\n\nPlease set NODE_HOME in your environment to the location where your nodejs installed"
- fi
-else
- EXECUTABLE_NODE="node"
- which ${EXECUTABLE_NODE} > /dev/null 2>&1 || fail "ERROR: NODE_HOME is not set and not 'node' command found in your path"
-fi
-
-# Check hvigor wrapper script
-if [ ! -r "$HVIGOR_WRAPPER_SCRIPT" ];then
- fail "ERROR: Couldn't find hvigor/hvigor-wrapper.js in ${HVIGOR_APP_HOME}"
-fi
-
-# start hvigor-wrapper script
-exec "${EXECUTABLE_NODE}" \
- "${HVIGOR_WRAPPER_SCRIPT}" "$@"
diff --git a/storage/storagefilejstest/hvigorw.bat b/storage/storagefilejstest/hvigorw.bat
deleted file mode 100644
index a9cc1302dc821de7f9f82c3327673a730945ec7d..0000000000000000000000000000000000000000
--- a/storage/storagefilejstest/hvigorw.bat
+++ /dev/null
@@ -1,70 +0,0 @@
-@rem Copyright (C) 2023 Huawei Device Co., Ltd.
-@rem Licensed under the Apache License, Version 2.0 (the "License");
-@rem you may not use this file except in compliance with the License.
-@rem You may obtain a copy of the License at
-@rem
-@rem http://www.apache.org/licenses/LICENSE-2.0
-@rem
-@rem Unless required by applicable law or agreed to in writing, software
-@rem distributed under the License is distributed on an "AS IS" BASIS,
-@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-@rem See the License for the specific language governing permissions and
-@rem limitations under the License.
-
-@if "%DEBUG%" == "" @echo off
-@rem ##########################################################################
-@rem
-@rem Hvigor startup script for Windows
-@rem
-@rem ##########################################################################
-
-@rem Set local scope for the variables with windows NT shell
-if "%OS%"=="Windows_NT" setlocal
-
-set DIRNAME=%~dp0
-if "%DIRNAME%" == "" set DIRNAME=.
-set APP_BASE_NAME=%~n0
-set APP_HOME=%DIRNAME%
-
-@rem Resolve any "." and ".." in APP_HOME to make it shorter.
-for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi
-
-set WRAPPER_MODULE_PATH=%APP_HOME%\hvigor\hvigor-wrapper.js
-set NODE_EXE=node.exe
-
-goto start
-
-:start
-@rem Find node.exe
-if defined NODE_HOME goto findNodeFromNodeHome
-
-%NODE_EXE% --version >NUL 2>&1
-if "%ERRORLEVEL%" == "0" goto execute
-
-echo.
-echo ERROR: NODE_HOME is not set and no 'node' command could be found in your PATH.
-echo.
-echo Please set the NODE_HOME variable in your environment to match the
-echo location of your NodeJs installation.
-
-goto fail
-
-:findNodeFromNodeHome
-set NODE_HOME=%NODE_HOME:"=%
-set NODE_EXE_PATH=%NODE_HOME%/%NODE_EXE%
-
-if exist "%NODE_EXE_PATH%" goto execute
-echo.
-echo ERROR: NODE_HOME is not set and no 'node' command could be found in your PATH.
-echo.
-echo Please set the NODE_HOME variable in your environment to match the
-echo location of your NodeJs installation.
-
-goto fail
-
-:execute
-@rem Execute hvigor
-"%NODE_EXE%" %WRAPPER_MODULE_PATH% %*
-
-:fail
-exit /b 1
diff --git a/storage/storagefilejstest/oh-package.json5 b/storage/storagefilejstest/oh-package.json5
deleted file mode 100644
index 1a98aac1810691829d1f9908395de4863cb0623d..0000000000000000000000000000000000000000
--- a/storage/storagefilejstest/oh-package.json5
+++ /dev/null
@@ -1,26 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-{
- "license": "",
- "devDependencies": {
- "@ohos/hypium": "1.0.6"
- },
- "author": "",
- "name": "myapplication454434",
- "description": "Please describe the basic information.",
- "main": "",
- "version": "1.0.0",
- "dependencies": {}
-}
diff --git a/storage/storagefilejstest/src/main/config.json b/storage/storagefilejstest/src/main/config.json
new file mode 100644
index 0000000000000000000000000000000000000000..6d66602d91345d2891de3d8792a339216e7929bb
--- /dev/null
+++ b/storage/storagefilejstest/src/main/config.json
@@ -0,0 +1,96 @@
+{
+ "app": {
+ "bundleName": "ohos.acts.storage.file",
+ "vendor": "example",
+ "version": {
+ "code": 1000000,
+ "name": "1.0.0"
+ },
+ "apiVersion": {
+ "compatible": 4,
+ "target": 5
+ }
+ },
+ "deviceConfig": {},
+ "module": {
+ "package": "ohos.acts.storage.file",
+ "name": ".entry",
+ "deviceType": [
+ "tablet",
+ "default",
+ "phone"
+ ],
+ "distro": {
+ "deliveryWithInstall": true,
+ "moduleName": "entry",
+ "moduleType": "entry",
+ "installationFree": true
+ },
+ "abilities": [
+ {
+ "skills": [
+ {
+ "entities": [
+ "entity.system.home"
+ ],
+ "actions": [
+ "action.system.home"
+ ]
+ }
+ ],
+ "orientation": "unspecified",
+ "formsEnabled": false,
+ "name": ".MainAbility",
+ "srcLanguage": "js",
+ "srcPath": "MainAbility",
+ "icon": "$media:icon",
+ "description": "$string:MainAbility_desc",
+ "label": "$string:MainAbility_label",
+ "type": "page",
+ "visible": true,
+ "launchType": "standard"
+ },
+ {
+ "orientation": "unspecified",
+ "formsEnabled": false,
+ "name": ".TestAbility",
+ "srcLanguage": "js",
+ "srcPath": "TestAbility",
+ "icon": "$media:icon",
+ "description": "$string:TestAbility_desc",
+ "label": "$string:TestAbility_label",
+ "type": "page",
+ "visible": true,
+ "launchType": "standard"
+ }
+ ],
+ "js": [
+ {
+ "pages": [
+ "pages/index/index"
+ ],
+ "name": "default",
+ "window": {
+ "designWidth": 720,
+ "autoDesignWidth": false
+ }
+ },
+ {
+ "pages": [
+ "pages/index/index"
+ ],
+ "name": ".TestAbility",
+ "window": {
+ "designWidth": 720,
+ "autoDesignWidth": false
+ }
+ }
+ ],
+ "testRunner": {
+ "name": "OpenHarmonyTestRunner",
+ "srcPath": "TestRunner"
+ },
+ "mainAbility": ".MainAbility",
+ "srcPath": ""
+ }
+}
\ No newline at end of file
diff --git a/storage/storagefilejstest/src/main/js/MainAbility/app.js b/storage/storagefilejstest/src/main/js/MainAbility/app.js
new file mode 100644
index 0000000000000000000000000000000000000000..38b923e9598eb7b023ac98bef564fedd06a081f7
--- /dev/null
+++ b/storage/storagefilejstest/src/main/js/MainAbility/app.js
@@ -0,0 +1,23 @@
+/*
+ * Copyright (C) 2021 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+export default {
+ onCreate() {
+ console.info('ohos.acts.storage.file onCreate');
+ },
+ onDestroy() {
+ console.info('ohos.acts.storage.file onDestroy');
+ }
+};
diff --git a/storage/storagefileurijstest/entry/src/main/js/MainAbility/i18n/en-US.json b/storage/storagefilejstest/src/main/js/MainAbility/i18n/en-US.json
similarity index 61%
rename from storage/storagefileurijstest/entry/src/main/js/MainAbility/i18n/en-US.json
rename to storage/storagefilejstest/src/main/js/MainAbility/i18n/en-US.json
index a4c13dcbdc39c537073f638393d7726ac9a5cdc4..ead52ed2e09ec82aaf7aa9f4e714ed39ea88308e 100644
--- a/storage/storagefileurijstest/entry/src/main/js/MainAbility/i18n/en-US.json
+++ b/storage/storagefilejstest/src/main/js/MainAbility/i18n/en-US.json
@@ -1,6 +1,6 @@
-{
- "strings": {
- "hello": "Hello",
- "world": "World"
- }
+{
+ "strings": {
+ "hello": "Hello",
+ "world": "Test"
+ }
}
\ No newline at end of file
diff --git a/storage/storagefileiov9jstest/entry/src/main/js/MainAbility/i18n/zh-CN.json b/storage/storagefilejstest/src/main/js/MainAbility/i18n/zh-CN.json
similarity index 61%
rename from storage/storagefileiov9jstest/entry/src/main/js/MainAbility/i18n/zh-CN.json
rename to storage/storagefilejstest/src/main/js/MainAbility/i18n/zh-CN.json
index b1c02368f72f929e4375a43170444de95dcc5984..3f48f2585b24a8fe4a745e8ee2972a9e991a7803 100644
--- a/storage/storagefileiov9jstest/entry/src/main/js/MainAbility/i18n/zh-CN.json
+++ b/storage/storagefilejstest/src/main/js/MainAbility/i18n/zh-CN.json
@@ -1,6 +1,6 @@
-{
- "strings": {
- "hello": "您好",
- "world": "世界"
- }
+{
+ "strings": {
+ "hello": "您好",
+ "world": "测试"
+ }
}
\ No newline at end of file
diff --git a/storage/storagefilejstest/src/main/js/MainAbility/pages/index/index.css b/storage/storagefilejstest/src/main/js/MainAbility/pages/index/index.css
new file mode 100644
index 0000000000000000000000000000000000000000..6fda792753f2e15f22b529c7b90a82185b2770bf
--- /dev/null
+++ b/storage/storagefilejstest/src/main/js/MainAbility/pages/index/index.css
@@ -0,0 +1,9 @@
+.container {
+ flex-direction: column;
+ justify-content: center;
+ align-items: center;
+}
+
+.title {
+ font-size: 100px;
+}
diff --git a/storage/storagefileurijstest/entry/src/ohosTest/js/TestAbility/pages/index/index.hml b/storage/storagefilejstest/src/main/js/MainAbility/pages/index/index.hml
similarity index 100%
rename from storage/storagefileurijstest/entry/src/ohosTest/js/TestAbility/pages/index/index.hml
rename to storage/storagefilejstest/src/main/js/MainAbility/pages/index/index.hml
diff --git a/storage/storagefilejstest/src/main/js/MainAbility/pages/index/index.js b/storage/storagefilejstest/src/main/js/MainAbility/pages/index/index.js
new file mode 100644
index 0000000000000000000000000000000000000000..6a9118dbb96efe627c20c435fdc1286f5d8611bf
--- /dev/null
+++ b/storage/storagefilejstest/src/main/js/MainAbility/pages/index/index.js
@@ -0,0 +1,34 @@
+/*
+ * Copyright (C) 2021 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import app from '@system.app'
+
+
+const injectRef = Object.getPrototypeOf(global) || global
+injectRef.regeneratorRuntime = require('@babel/runtime/regenerator')
+
+export default {
+ data: {
+ title: ''
+ },
+ onInit() {
+ this.title = this.$t('strings.world');
+ },
+ onShow() {
+ console.info('onShow finish')
+ },
+ onReady() {
+ },
+}
\ No newline at end of file
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/TestAbility/app.js b/storage/storagefilejstest/src/main/js/TestAbility/app.js
similarity index 62%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/TestAbility/app.js
rename to storage/storagefilejstest/src/main/js/TestAbility/app.js
index 469c4f1380182e0dccb04f17eb95d9b503a56d29..d5ee271df29e516d1c8929054283e5f2bf5c981c 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/TestAbility/app.js
+++ b/storage/storagefilejstest/src/main/js/TestAbility/app.js
@@ -1,33 +1,31 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-import hilog from '@ohos.hilog';
-import AbilityDelegatorRegistry from '@ohos.app.ability.abilityDelegatorRegistry';
-import { Hypium } from '@ohos/hypium';
-import testsuite from '../test/List.test';
-
-export default {
- onCreate() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'TestApplication onCreate');
- var abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator()
- var abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments()
- hilog.info(0x0000, 'testTag', '%{public}s', 'start run testcase!!!');
- Hypium.hypiumTest(abilityDelegator, abilityDelegatorArguments, testsuite)
- },
- onDestroy() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'TestApplication onDestroy');
- }
-};
-
-
+/*
+ * Copyright (c) 2022 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry'
+import { Hypium } from '@ohos/hypium'
+import testsuite from '../test/List.test'
+
+export default {
+ onCreate() {
+ console.info('TestApplication onCreate')
+ var abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator()
+ var abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments()
+ console.info('start run testcase!!!')
+ Hypium.hypiumTest(abilityDelegator, abilityDelegatorArguments, testsuite)
+ },
+ onDestroy() {
+ console.info("TestApplication onDestroy");
+ }
+};
diff --git a/storage/storagefileurijstest/entry/src/ohosTest/js/TestAbility/i18n/en-US.json b/storage/storagefilejstest/src/main/js/TestAbility/i18n/en-US.json
similarity index 100%
rename from storage/storagefileurijstest/entry/src/ohosTest/js/TestAbility/i18n/en-US.json
rename to storage/storagefilejstest/src/main/js/TestAbility/i18n/en-US.json
diff --git a/storage/storagefileurijstest/entry/src/ohosTest/js/TestAbility/i18n/zh-CN.json b/storage/storagefilejstest/src/main/js/TestAbility/i18n/zh-CN.json
similarity index 100%
rename from storage/storagefileurijstest/entry/src/ohosTest/js/TestAbility/i18n/zh-CN.json
rename to storage/storagefilejstest/src/main/js/TestAbility/i18n/zh-CN.json
diff --git a/storage/storagefilejstest/src/main/js/TestAbility/pages/index/index.css b/storage/storagefilejstest/src/main/js/TestAbility/pages/index/index.css
new file mode 100644
index 0000000000000000000000000000000000000000..b21c92c6290ea747bd891e2ab673721afc5521ed
--- /dev/null
+++ b/storage/storagefilejstest/src/main/js/TestAbility/pages/index/index.css
@@ -0,0 +1,30 @@
+.container {
+ display: flex;
+ flex-direction: column;
+ justify-content: center;
+ align-items: center;
+ left: 0px;
+ top: 0px;
+ width: 100%;
+ height: 100%;
+}
+
+.title {
+ font-size: 60px;
+ text-align: center;
+ width: 100%;
+ height: 40%;
+ margin: 10px;
+}
+
+@media screen and (device-type: phone) and (orientation: landscape) {
+ .title {
+ font-size: 60px;
+ }
+}
+
+@media screen and (device-type: tablet) and (orientation: landscape) {
+ .title {
+ font-size: 100px;
+ }
+}
\ No newline at end of file
diff --git a/storage/storagesecuritylabeljstest/entry/src/ohosTest/js/TestAbility/pages/index/index.hml b/storage/storagefilejstest/src/main/js/TestAbility/pages/index/index.hml
similarity index 100%
rename from storage/storagesecuritylabeljstest/entry/src/ohosTest/js/TestAbility/pages/index/index.hml
rename to storage/storagefilejstest/src/main/js/TestAbility/pages/index/index.hml
diff --git a/storage/storagefileurijstest/entry/src/ohosTest/js/TestAbility/pages/index/index.js b/storage/storagefilejstest/src/main/js/TestAbility/pages/index/index.js
similarity index 93%
rename from storage/storagefileurijstest/entry/src/ohosTest/js/TestAbility/pages/index/index.js
rename to storage/storagefilejstest/src/main/js/TestAbility/pages/index/index.js
index ad113c0d214ce0d80c42c75c62d881547b6294ee..d94b75c085fa1c16a0b2721609b18c57a7295476 100644
--- a/storage/storagefileurijstest/entry/src/ohosTest/js/TestAbility/pages/index/index.js
+++ b/storage/storagefilejstest/src/main/js/TestAbility/pages/index/index.js
@@ -1,5 +1,5 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
+/*
+ * Copyright (c) 2022 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
@@ -12,6 +12,7 @@
* See the License for the specific language governing permissions and
* limitations under the License.
*/
+
export default {
data: {
title: ""
diff --git a/storage/storagesecuritylabeljstest/entry/src/ohosTest/js/TestRunner/OpenHarmonyTestRunner.js b/storage/storagefilejstest/src/main/js/TestRunner/OpenHarmonyTestRunner.js
similarity index 52%
rename from storage/storagesecuritylabeljstest/entry/src/ohosTest/js/TestRunner/OpenHarmonyTestRunner.js
rename to storage/storagefilejstest/src/main/js/TestRunner/OpenHarmonyTestRunner.js
index 03ccc5b691574b1d5bc46adefc08d9ddfc4a1f5c..b9e78ce7cf73f1ade6ba52a408a44e33f5430f0d 100644
--- a/storage/storagesecuritylabeljstest/entry/src/ohosTest/js/TestRunner/OpenHarmonyTestRunner.js
+++ b/storage/storagefilejstest/src/main/js/TestRunner/OpenHarmonyTestRunner.js
@@ -1,5 +1,5 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
+/*
+ * Copyright (c) 2022 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
@@ -12,30 +12,48 @@
* See the License for the specific language governing permissions and
* limitations under the License.
*/
-import hilog from '@ohos.hilog';
-import AbilityDelegatorRegistry from '@ohos.app.ability.abilityDelegatorRegistry';
+
+import AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry'
+
+function translateParamsToString(parameters) {
+ const keySet = new Set([
+ '-s class', '-s notClass', '-s suite', '-s itName',
+ '-s level', '-s testType', '-s size', '-s timeout',
+ '-s package', '-s dryRun'
+ ])
+ let targetParams = '';
+ for (const key in parameters) {
+ if (keySet.has(key)) {
+ targetParams += ' ' + key + ' ' + parameters[key]
+ }
+ }
+ return targetParams.trim()
+}
export default {
onPrepare() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'OpenHarmonyTestRunner OnPrepare');
+ console.info('OpenHarmonyTestRunner OnPrepare')
},
onRun() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'OpenHarmonyTestRunner onRun run');
+ console.log('OpenHarmonyTestRunner onRun run')
var abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments()
var abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator()
var testAbilityName = abilityDelegatorArguments.parameters['-p'] + '.TestAbility'
+
var cmd = 'aa start -d 0 -a ' + testAbilityName + ' -b ' + abilityDelegatorArguments.bundleName
+ cmd += ' ' + translateParamsToString(abilityDelegatorArguments.parameters)
var debug = abilityDelegatorArguments.parameters["-D"]
+ console.info('debug value : '+debug)
if (debug == 'true')
{
cmd += ' -D'
}
- hilog.info(0x0000, 'testTag', 'cmd : %{public}s', cmd);
+ console.info('cmd : '+cmd)
abilityDelegator.executeShellCommand(cmd, (err, data) => {
- hilog.info(0x0000, 'testTag', 'executeShellCommand : err : %{public}s', JSON.stringify(err) ?? '');
- hilog.info(0x0000, 'testTag', 'executeShellCommand : data : %{public}s', data.stdResult ?? '');
- hilog.info(0x0000, 'testTag', 'executeShellCommand : data : %{public}s', data.exitCode ?? '');
+ console.info('executeShellCommand : err : ' + JSON.stringify(err));
+ console.info('executeShellCommand : data : ' + data.stdResult);
+ console.info('executeShellCommand : data : ' + data.exitCode);
})
}
-};
\ No newline at end of file
+};
diff --git a/storage/storagefilejstest/entry/src/ohosTest/js/test/Common.js b/storage/storagefilejstest/src/main/js/test/Common.js
similarity index 88%
rename from storage/storagefilejstest/entry/src/ohosTest/js/test/Common.js
rename to storage/storagefilejstest/src/main/js/test/Common.js
index 8b8da8dff8d15d97b638eebe83c4edfbcf3c7b14..e5085412f78440b882f79b7fdff8cb1bd3b39ac0 100644
--- a/storage/storagefilejstest/entry/src/ohosTest/js/test/Common.js
+++ b/storage/storagefilejstest/src/main/js/test/Common.js
@@ -1,96 +1,96 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import fileio from '@ohos.fileio';
-import featureAbility from '@ohos.ability.featureAbility'
-
-export const FILE_CONTENT = 'hello world';
-
-import {
- describe, it, expect
-}
-from '@ohos/hypium'
-
-export function prepareFile(fpath, content) {
- try {
- let fd = fileio.openSync(fpath, 0o102, 0o666)
- fileio.ftruncateSync(fd)
- fileio.writeSync(fd, content)
- fileio.fsyncSync(fd)
- fileio.closeSync(fd)
- return true
- }
- catch (e) {
- console.log('Failed to prepareFile for ' + e)
- return false
- }
-}
-export function prepareEmptyFile(fpath) {
- try {
- let fd = fileio.openSync(fpath, 0o102, 0o777)
- fileio.closeSync(fd)
- return true
- }
- catch (e) {
- console.log('Failed to prepareFile for ' + e)
- return false
- }
-}
-
-export async function nextFileName(testName) {
- var context = featureAbility.getContext();
- let data = await context.getCacheDir();
- let BASE_PATH = data + '/';
- return BASE_PATH + testName
-}
-export async function fileName(testName) {
- var context = featureAbility.getContext();
- let data = await context.getFilesDir();
- let BASE_PATH = data + '/';
- return BASE_PATH + testName
-}
-export async function cacheFileName(testName) {
- var context = featureAbility.getContext();
- let data = await context.getFilesDir();
- let BASE_PATH = data + '/cache/';
- return BASE_PATH + testName
-}
-
-export function sleep(n) {
- var start = new Date().getTime();
- while (true) {
- if (new Date().getTime() - start > n) {
- break;
- }
- }
-}
-
-export function randomString(num) {
- let len= num;
- var $chars = 'aaaabbbbcccc';
- var maxPos = $chars.length;
- var pwd = '';
- for (var i = 0; i < len; i++) {
- pwd += $chars.charAt(Math.floor(Math.random() * maxPos));
- }
- return pwd;
-}
-
-export {
- fileio,
- describe,
- it,
- expect
+/*
+ * Copyright (C) 2021 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import fileio from '@ohos.fileio';
+import featureAbility from '@ohos.ability.featureAbility'
+
+export const FILE_CONTENT = 'hello world';
+
+import {
+ describe, it, expect
+}
+from '@ohos/hypium'
+
+export function prepareFile(fpath, content) {
+ try {
+ let fd = fileio.openSync(fpath, 0o102, 0o666)
+ fileio.ftruncateSync(fd)
+ fileio.writeSync(fd, content)
+ fileio.fsyncSync(fd)
+ fileio.closeSync(fd)
+ return true
+ }
+ catch (e) {
+ console.log('Failed to prepareFile for ' + e)
+ return false
+ }
+}
+export function prepareEmptyFile(fpath) {
+ try {
+ let fd = fileio.openSync(fpath, 0o102, 0o777)
+ fileio.closeSync(fd)
+ return true
+ }
+ catch (e) {
+ console.log('Failed to prepareFile for ' + e)
+ return false
+ }
+}
+
+export async function nextFileName(testName) {
+ var context = featureAbility.getContext();
+ let data = await context.getCacheDir();
+ let BASE_PATH = data + '/';
+ return BASE_PATH + testName
+}
+export async function fileName(testName) {
+ var context = featureAbility.getContext();
+ let data = await context.getFilesDir();
+ let BASE_PATH = data + '/';
+ return BASE_PATH + testName
+}
+export async function cacheFileName(testName) {
+ var context = featureAbility.getContext();
+ let data = await context.getFilesDir();
+ let BASE_PATH = data + '/cache/';
+ return BASE_PATH + testName
+}
+
+export function sleep(n) {
+ var start = new Date().getTime();
+ while (true) {
+ if (new Date().getTime() - start > n) {
+ break;
+ }
+ }
+}
+
+export function randomString(num) {
+ let len= num;
+ var $chars = 'aaaabbbbcccc';
+ var maxPos = $chars.length;
+ var pwd = '';
+ for (var i = 0; i < len; i++) {
+ pwd += $chars.charAt(Math.floor(Math.random() * maxPos));
+ }
+ return pwd;
+}
+
+export {
+ fileio,
+ describe,
+ it,
+ expect
};
\ No newline at end of file
diff --git a/storage/storagefilejstest/entry/src/ohosTest/js/test/File.test.js b/storage/storagefilejstest/src/main/js/test/File.test.js
similarity index 97%
rename from storage/storagefilejstest/entry/src/ohosTest/js/test/File.test.js
rename to storage/storagefilejstest/src/main/js/test/File.test.js
index 9108d211ac4a74de29e02fbbb5497eee38caded5..7ddc82eba3717ae246ab96daf7fbaa5f893b3d14 100644
--- a/storage/storagefilejstest/entry/src/ohosTest/js/test/File.test.js
+++ b/storage/storagefilejstest/src/main/js/test/File.test.js
@@ -1,3937 +1,3937 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import fileio from '@ohos.fileio';
-import file from '@system.file';
-import document from '@ohos.document';
-import {
- describe,
- it,
- expect
-}
-from '@ohos/hypium'
-import {
- FILE_CONTENT,
- prepareFile,
- fileName,
- randomString,
- cacheFileName,
- prepareEmptyFile,
- nextFileName,
- sleep
-}
-from './Common'
-
-export default function fileTest() {
-describe('fileTest', function () {
-
- /**
- * @tc.number SUB_STORAGE_File_Delete_0100
- * @tc.name File_Delete_001
- * @tc.desc Function of API, delete file.The test file is exist.
- */
- it('File_Delete_001', 0, async function (done) {
- let fpath = await fileName('File_Delete_001');
- expect(prepareFile(fpath, 'hello')).assertTrue();
- file.delete({
- uri: 'internal://cache/../files/File_Delete_001',
- success: function () {
- console.info('File_Delete_001 call delete success');
- done();
- },
- fail: function (data, code) {
- console.info('File_Delete_001 call delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Delete_0200
- * @tc.name File_Delete_002
- * @tc.desc Function of API, delete dir.The dir is empty.
- */
- it('File_Delete_002', 0, async function (done) {
- file.mkdir({
- uri: 'internal://cache/File_Delete_002',
- success: function () {
- console.info('File_Delete_002 call mkdir success.');
- file.delete({
- uri: 'internal://cache/File_Delete_002',
- success: function () {
- console.info('File_Delete_002 call delete success.');
- done();
- },
- fail: function (data, code) {
- console.info('File_Delete_002 call delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_Delete_002 call mkdir fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Delete_0300
- * @tc.name File_Delete_003
- * @tc.desc Function of API, error code: 202 The test file or dir are exist.
- */
- it('File_Delete_003', 0, async function (done) {
- file.delete({
- uri: 'internal://ohos/workspace/text.txt',
- success: function () {
- console.info('File_Delete_003 call delete success.');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_Delete_003 call delete fail, code: ' + code + ', data: ' + data);
- expect(code == 202).assertTrue();
- done();
- },
- });
-
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Delete_0400
- * @tc.name File_Delete_004
- * @tc.desc Function of API, error code: 300 The dir is exist with files.
- */
- it('File_Delete_004', 0, async function (done) {
- let dpath = await fileName('File_Delete_004');
- let fpath = dpath + '/File_Delete_004';
- fileio.mkdirSync(dpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- file.delete({
- uri: 'internal://app/File_Delete_004',
- success: function () {
- console.info('File_Delete_004 call delete success.');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_Delete_004 call delete fail, code: ' + code + ', data: ' + data);
- expect(code == 300).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Delete_0500
- * @tc.name File_Delete_005
- * @tc.desc Function of API, error code: 301 The file and dir are not exist.
- */
- it('File_Delete_005', 0, async function (done) {
- file.delete({
- uri: 'internal://app/File_Delete_005',
- success: function () {
- console.info('File_Delete_005 call delete success.');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_Delete_005 call delete fail, code: ' + code + ', data: ' + data);
- expect(code == 301).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Delete_0600
- * @tc.name File_Delete_006
- * @tc.desc uri address length more than 4096 The test file is exist.
- */
- it('File_Delete_006', 0, async function (done) {
- let firstPath = randomString(32);
- let dpath = await fileName(firstPath);
- let uri = 'internal://cache/' + firstPath;
- fileio.mkdirSync(dpath);
- for (let i = 0; i < 16; i++) {
- console.info('frequency' + i);
- let sonPath = randomString(251);
- uri = uri + '/f' + sonPath;
- }
- file.delete({
- uri: uri,
- success: function () {
- console.info('File_Delete_006 call delete success');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_Delete_006 call delete fail, code: ' + code + ', data: ' + data);
- expect(code == 300).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Delete_0700
- * @tc.name File_Delete_007
- * @tc.desc Function of API, delete file from cache.The test file on cache.
- */
- it('File_Delete_007', 0, async function (done) {
- file.writeText({
- uri: 'internal://cache/File_Delete_007',
- text: 'test',
- success: function () {
- console.info('File_Delete_007 call writeText success');
- file.delete({
- uri: 'internal://cache/File_Delete_007',
- success: function () {
- console.info('File_Delete_007 call delete success');
- done();
- },
- fail: function (data, code) {
- console.info('File_Delete_007 call delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_Delete_007 call writeText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Delete_0800
- * @tc.name File_Delete_008.
- * @tc.desc Function of API, delete file from Virtual path.The test file is exist.
- */
- it('File_Delete_008', 0, async function (done) {
- file.writeText({
- uri: 'internal://cache/../cache/File_Delete_008',
- text: 'Text that just for test.',
- success: function () {
- console.info('File_Delete_008 call writeText success');
- file.delete({
- uri: 'internal://cache/../cache/File_Delete_008',
- success: function () {
- console.info('File_Delete_008 call delete success');
- done();
- },
- fail: function (data, code) {
- console.info('File_Delete_008 call delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- complete: function () {
- console.info('delete completed');
- }
- });
- },
- fail: function (data, code) {
- console.info('File_Delete_008 call writeText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_writeText_0100
- * @tc.name File_writeText_001
- * @tc.desc Function of API, write to file(app path).The test file is not exist.
- */
- it('File_writeText_001', 0, async function (done) {
- file.writeText({
- uri: 'internal://cache/File_writeText_001',
- text: 'sawyerwang.',
- success: function () {
- console.info('File_writeText_001 call writeText success');
- file.readText({
- uri: 'internal://cache/File_writeText_001',
- success: function (data) {
- console.info('File_writeText_001 call read success. Content: ' );
- file.delete({
- uri: 'internal://cache/File_writeText_001',
- success: function () {
- console.info('File_writeText_001 call delete success');
- done();
- },
- fail: function (data, code) {
- console.info('File_writeText_001 call delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeText_001 call read fail , code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeText_001 call writeText fail , code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_writeText_0200
- * @tc.name File_writeText_002
- * @tc.desc Function of API, write to file.The test file is exist, it can be edited.
- */
- it('File_writeText_002', 0, async function (done) {
- file.writeText({
- uri: 'internal://cache/File_writeText_002',
- text: 'Text1.',
- success: function () {
- console.info('File_writeText_002 call writeText success.');
- file.writeText({
- uri: 'internal://cache/File_writeText_002',
- text: 'Text2.',
- append: true,
- success: function () {
- console.info('File_writeText_002 call writeText success.');
- file.readText({
- uri: 'internal://cache/File_writeText_002',
- success: function (data) {
- console.info('File_writeText_002 call read success. Content: ' );
- file.delete({
- uri: 'internal://cache/File_writeText_002',
- success: function () {
- console.info('File_writeText_002 call delete success');
- done();
- },
- fail: function (data, code) {
- console.info('File_writeText_002 call delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeText_002 call read fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeText_002 call writeText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeText_002 call writeText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_writeText_0300
- * @tc.name File_writeText_003
- * @tc.desc Different types of strings for text.
- */
- it('File_writeText_003', 0, async function (done) {
- let txt = 'hello 你好 ????? こんにちは ?????.'
- file.writeText({
- uri: 'internal://cache/File_writeText_003',
- text: txt,
- success: function () {
- console.info('File_writeText_003 call writeText success.');
- file.readText({
- uri: 'internal://cache/File_writeText_003',
- success: function (data) {
- console.info('File_writeText_003 call read success. Content: ' );
- file.delete({
- uri: 'internal://cache/File_writeText_003',
- success: function () {
- console.info('File_writeText_003 call delete success');
- done();
- },
- fail: function (data, code) {
- console.info('File_writeText_003 call delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeText_003 call read fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeText_003 call writeText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_writeText_0400
- * @tc.name File_writeText_004
- * @tc.desc Defferent encoding(UTF-8).
- */
- it('File_writeText_004', 0, async function (done) {
- file.writeText({
- uri: 'internal://cache/File_writeText_004',
- text: 'hello',
- encoding: 'UTF-8',
- success: function () {
- console.info('File_writeText_004 call writeText success.');
- file.readText({
- uri: 'internal://cache/File_writeText_004',
- encoding: 'UTF-8',
- success: function (data) {
- console.info('File_writeText_004 call readText success. Content: ' );
- file.delete({
- uri: 'internal://cache/File_writeText_004',
- success: function () {
- console.info('File_writeText_004 delete success');
- done();
- },
- fail: function (data, code) {
- console.info('File_writeText_004 delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeText_004 call readText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeText_004 call writeText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_writeText_0500
- * @tc.name File_writeText_005
- * @tc.desc Function of API, append mode.The test file is exist and it can be edited.
- */
- it('File_writeText_005', 0, async function (done) {
- file.writeText({
- uri: 'internal://cache/File_writeText_005',
- text: 'hello,world',
- success: function () {
- console.info('File_writeText_005 call writeText success.');
- file.writeText({
- uri: 'internal://cache/File_writeText_005',
- text: 'hello',
- append: true,
- success: function () {
- console.info('File_writeText_005 call writeText success.');
- file.readText({
- uri: 'internal://cache/File_writeText_005',
- success: function (data) {
- console.info('File_writeText_005 call read success ' );
- file.delete({
- uri: 'internal://cache/File_writeText_005',
- success: function () {
- console.info('File_writeText_005 call delete success');
- done();
- },
- fail: function (data, code) {
- console.info('File_writeText_005 call delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeText_005 call readText fail , code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeText_005 call writeText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeText_005 call writeText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_writeText_0600
- * @tc.name File_writeText_006
- * @tc.desc Function of API, non-append mode.The test file is exist and it can be edited.
- */
- it('File_writeText_006', 0, async function (done) {
- file.writeText({
- uri: 'internal://cache/File_writeText_006',
- text: 'hello',
- success: function () {
- console.info('File_writeText_006 call writeText success.');
- file.readText({
- uri: 'internal://cache/File_writeText_006',
- success: function (data) {
- console.info('File_writeText_006 call read success ' );
- file.delete({
- uri: 'internal://cache/File_writeText_006',
- success: function () {
- console.info('File_writeText_006 delete success');
- done();
- },
- fail: function (data, code) {
- console.info('File_writeText_006 delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeText_006 call readText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeText_006 call writeText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_writeText_0700
- * @tc.name File_writeText_007
- * @tc.desc Function of API, error code: 202 The test file and dir are exist.
- */
- it('File_writeText_007', 0, async function (done) {
- file.writeText({
- uri: '/data/accounts/account_0/appdata',
- text: 'hello',
- success: function () {
- console.info('File_writeText_007 call writeText success.');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_writeText_007, code: ' + code + ', data: ' + data);
- expect(code == 202).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_writeText_0800
- * @tc.name File_writeText_008
- * @tc.desc Function of API, error code: 300 The uri path is dir path.
- */
- it('File_writeText_008', 0, async function (done) {
- let dpath = await nextFileName('File_writeText_008d');
- fileio.mkdirSync(dpath);
- file.writeText({
- uri: 'internal://cache/File_writeText_008d/',
- text: 'hello',
- success: function () {
- console.info('File_writeText_008 call writeText success.');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_writeText_008 , code: ' + code + ', data: ' + data);
- expect(code == 300).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_writeText_0900
- * @tc.name File_writeText_009
- * @tc.desc Function of API, error code: 300.The file path is not exist.
- */
- it('File_writeText_009', 0, async function (done) {
- file.writeText({
- uri: 'internal://app/File_writeText_009d/File_writeText_009',
- text: 'test',
- success: function () {
- console.info('File_writeText_009 call writeText success.');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_writeText_009 , code: ' + code + ', data: ' + data);
- expect(code == 300).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_writeText_1000
- * @tc.name File_writeText_010
- * @tc.desc Function of API, write to file(cache path).The test file is not exist.
- */
- it('File_writeText_010', 0, async function (done) {
- file.writeText({
- uri: 'internal://cache/File_writeText_010',
- text: 'test',
- success: function () {
- console.info('File_writeText_010 mkdir success');
- file.delete({
- uri: 'internal://cache/File_writeText_010',
- success: function () {
- console.info('File_writeText_010 delete success');
- done();
- },
- fail: function (data, code) {
- console.info('File_writeText_010 delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeText_010 writeText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_writeText_1100
- * @tc.name File_writeText_011
- * @tc.desc Function of API, Virtual path.The test file is exist.
- */
- it('File_writeText_011', 0, async function (done) {
- file.writeText({
- uri: 'internal://cache/../cache/File_writeText_011',
- text: 'sawyerwang',
- success: function () {
- console.info('File_writeText_011 writeText success ');
- file.readText({
- uri: 'internal://cache/../cache/File_writeText_011',
- success: function (data) {
- console.info('File_writeText_011 readText success ' );
- file.delete({
- uri: 'internal://cache/../cache/File_writeText_011',
- success: function () {
- console.info('File_writeText_011 delete success');
- done();
- },
- fail: function (data, code) {
- console.info('File_writeText_011 delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeText_011 readText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeText_011 writeText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_writeText_1300
- * @tc.name File_writeText_013
- * @tc.desc Function of API, write file out of package, Virtual path, save the dir authority.The test file is exist.
- */
- it('File_writeText_013', 0, async function (done) {
- file.writeText({
- uri: 'internal://app/notdir/File_writeText_013',
- text: 'sawyerwang',
- success: function () {
- console.info('File_writeText_013 mkdir success');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- expect(code == 300).assertTrue();
- console.info('File_writeText_013 , code: ' + code + ', data: ' + data);
- done();
- },
- complete: function () {
- console.info('writeText completed');
- }
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_writeArrayBuffer_0100
- * @tc.name File_writeArrayBuffer_001
- * @tc.desc Write the buffer content to file.(cache path, append mode) The file path is not exist.
- */
- it('File_writeArrayBuffer_001', 0, async function (done) {
- let buf = new Uint8Array([48, 49, 50, 51, 65, 66, 67, 68, 32, 33]);
- file.writeArrayBuffer({
- uri: 'internal://cache/File_writeArrayBuffer_001',
- buffer: buf,
- append: true,
- success: function () {
- console.info('File_writeArrayBuffer_001 call writeArrayBuffer success.');
- file.readArrayBuffer({
- uri: 'internal://cache/File_writeArrayBuffer_001',
- success: function (data) {
- console.info('File_writeArrayBuffer_001 call readArrayBuffer success.' );
- file.delete({
- uri: 'internal://cache/File_writeArrayBuffer_001',
- success: function () {
- console.info('File_writeArrayBuffer_001 delete success');
- done();
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_001 delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_001 readArrayBuffer fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_001 writeArrayBuffer fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_writeArrayBuffer_0200
- * @tc.name File_writeArrayBuffer_002
- * @tc.desc Write the buffer content to file.(cache path, non-append mode) The file path is not exist.
- */
- it('File_writeArrayBuffer_002', 0, async function (done) {
- let buf = new Uint8Array([48, 49, 50, 51, 65, 66, 67, 68, 32, 33]);
- file.writeArrayBuffer({
- uri: 'internal://cache/File_writeArrayBuffer_002',
- buffer: buf,
- success: function () {
- console.info('File_writeArrayBuffer_002 call writeArrayBuffer success.');
- file.readArrayBuffer({
- uri: 'internal://cache/File_writeArrayBuffer_002',
- success: function (data) {
- console.info('File_writeArrayBuffer_002 call readArrayBuffer success.' );
- file.delete({
- uri: 'internal://cache/File_writeArrayBuffer_002',
- success: function () {
- console.info('File_writeArrayBuffer_002 delete success');
- done();
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_002 delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_002 readArrayBuffer fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_002 writeArrayBuffer fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_writeArrayBuffer_0300
- * @tc.name File_writeArrayBuffer_003
- * @tc.desc Write the buffer content to file.(cache path, append mode) The file path is not exist.
- */
- it('File_writeArrayBuffer_003', 0, async function (done) {
- let buf = new Uint8Array([48, 49, 50, 51, 65, 66, 67, 68, 32, 33, 48, 49, 50, 51, 65, 66, 67, 68, 32, 33]);
- file.writeArrayBuffer({
- uri: 'internal://cache/File_writeArrayBuffer_003',
- buffer: buf,
- success: function () {
- console.info('File_writeArrayBuffer_003 call writeText success.');
- file.writeArrayBuffer({
- uri: 'internal://cache/File_writeArrayBuffer_003',
- buffer: buf,
- append: true,
- success: function () {
- console.info('File_writeArrayBuffer_003 call writeArrayBuffer success.');
- file.readArrayBuffer({
- uri: 'internal://cache/File_writeArrayBuffer_003',
- success: function (data) {
- console.info('File_writeArrayBuffer_003 readArrayBuffer success:' );
- done();
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_003 readArrayBuffer fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_003 writeArrayBuffer append fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_003 writeArrayBuffer fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_writeArrayBuffer_0400
- * @tc.name File_writeArrayBuffer_004
- * @tc.desc Write the buffer content to file.(cache path, non-append mode) The file path is exist.
- */
- it('File_writeArrayBuffer_004', 0, async function (done) {
- let buf = new Uint8Array([48, 49, 50, 51, 65, 66, 67, 68, 32, 33]);
- file.writeArrayBuffer({
- uri: 'internal://cache/File_writeArrayBuffer_004',
- buffer: buf,
- append: false,
- success: function () {
- console.info('File_writeArrayBuffer_004 success call writeText success.');
- file.writeArrayBuffer({
- uri: 'internal://cache/File_writeArrayBuffer_004',
- buffer: buf,
- append: false,
- success: function () {
- console.info('File_writeArrayBuffer_004 call writeArrayBuffer success.');
- file.readArrayBuffer({
- uri: 'internal://cache/File_writeArrayBuffer_004',
- success: function (data) {
- console.info('File_writeArrayBuffer_004: readArrayBuffer success ' );
- file.delete({
- uri: 'internal://cache/File_writeArrayBuffer_004',
- success: function () {
- console.info('File_writeArrayBuffer_004 call delete success');
- done();
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_004 delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_004 readArrayBuffer fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_004 writeArrayBuffer fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_004 writeText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_writeArrayBuffer_0500
- * @tc.name File_writeArrayBuffer_005
- * @tc.desc Function of API, set value for position.The file path is exist.
- */
- it('File_writeArrayBuffer_005', 0, async function (done) {
- let buf = new Uint8Array([48, 49, 50, 51, 65, 66, 67, 68, 32, 33, 44, 55, 66, 77]);
- file.writeArrayBuffer({
- uri: 'internal://cache/File_writeArrayBuffer_005',
- buffer: buf,
- success: function () {
- console.info('File_writeArrayBuffer_005 call writeText success.');
- file.writeArrayBuffer({
- uri: 'internal://cache/File_writeArrayBuffer_005',
- buffer: buf,
- position: 10,
- success: function () {
- console.info('File_writeArrayBuffer_005 call writeArrayBuffer success.');
- file.readArrayBuffer({
- uri: 'internal://cache/File_writeArrayBuffer_005',
- success: function (data) {
- console.info('File_writeArrayBuffer_005 read success:' );
- file.delete({
- uri: 'internal://cache/File_writeArrayBuffer_005',
- success: function () {
- console.info('File_writeArrayBuffer_005 call delete success');
- done();
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_005 delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_005 read fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_005 writeArrayBuffer fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_005 writeText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_writeArrayBuffer_0600
- * @tc.name File_writeArrayBuffer_006
- * @tc.desc Function of API, not set value for position & append.The file path is exist.
- */
- it('File_writeArrayBuffer_006', 0, async function (done) {
- let buf = new Uint8Array([48, 49, 50, 51, 65, 66, 67, 68, 32, 33]);
- file.writeArrayBuffer({
- uri: 'internal://cache/File_writeArrayBuffer_006',
- buffer: buf,
- success: function () {
- console.info('File_writeArrayBuffer_006 call writeText success.');
- file.writeArrayBuffer({
- uri: 'internal://cache/File_writeArrayBuffer_006',
- buffer: buf,
- success: function () {
- console.info('File_writeArrayBuffer_006 call writeArrayBuffer success.');
- file.readArrayBuffer({
- uri: 'internal://cache/File_writeArrayBuffer_006',
- success: function () {
- console.info('File_writeArrayBuffer_006 call readArrayBuffer pass');
- done();
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_006 readArrayBuffer fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_006 writeArrayBuffer fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_006 writeText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_writeArrayBuffer_0700
- * @tc.name File_writeArrayBuffer_007
- * @tc.desc Function of API, error code: 202
- */
- it('File_writeArrayBuffer_007', 0, async function (done) {
- let buf = new Uint8Array([48, 49, 50, 51, 65, 66, 67, 68, 32, 33]);
- file.writeArrayBuffer({
- uri: '',
- buffer: buf,
- success: function () {
- console.info('File_writeArrayBuffer_007 call writeArrayBuffer success.');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_007 , code: ' + code + ', data: ' + data);
- expect(code == 202).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_writeArrayBuffer_0800
- * @tc.name File_writeArrayBuffer_008
- * @tc.desc Function of API, error code: 300
- */
- it('File_writeArrayBuffer_008', 0, async function (done) {
- let buf = new Uint8Array([48, 49, 50, 51, 65, 66, 67, 68, 32, 33]);
- file.mkdir({
- uri: 'internal://app/File_writeArrayBuffer_008',
- success: function () {
- console.info('call mkdir success.');
- done();
- },
- fail: function (data, code) {
- console.error('call fail callback fail, code: ' + code + ', data: ' + data);
- },
- });
- file.writeArrayBuffer({
- uri: 'internal://app/notdir/File_writeArrayBuffer_008',
- buffer: buf,
- success: function () {
- console.info('File_writeArrayBuffer_008 call writeArrayBuffer success.');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_008 , code: ' + code + ', data: ' + data);
- expect(code == 300).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_writeArrayBuffer_0900
- * @tc.name File_writeArrayBuffer_009
- * @tc.desc Function of API, error code: 300
- */
- it('File_writeArrayBuffer_009', 0, async function (done) {
- let buf = new Uint8Array([1, 2, 3, 4, 5, 6, 7, 8]);
- file.writeArrayBuffer({
- uri: 'internal://cache/File_writeArrayBuffer_009',
- buffer: buf,
- success: function () {
- console.info('File_writeArrayBuffer_009 call writeArrayBuffer success');
- file.readArrayBuffer({
- uri: 'internal://cache/File_writeArrayBuffer_009',
- success: function (data) {
- console.info('File_writeArrayBuffer_009 call readArrayBuffer pass');
- file.delete({
- uri: 'internal://cache/File_writeArrayBuffer_009',
- success: function () {
- console.info('File_writeArrayBuffer_009 call delete success');
- done();
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_009 delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_009 readArrayBuffer fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_009 writeArrayBuffer fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_writeArrayBuffer_1000
- * @tc.name File_writeArrayBuffer_010
- * @tc.desc Function of API, path = cache, virtual path The test file is exist.
- */
- it('File_writeArrayBuffer_010', 0, async function (done) {
- let buf = new Uint8Array([48, 49, 50, 51, 65, 66, 67, 68, 32, 33]);
- file.writeArrayBuffer({
- uri: 'internal://cache/../cache/File_writeArrayBuffer_010',
- buffer: buf,
- append: true,
- success: function () {
- console.info('File_writeArrayBuffer_010 call writeArrayBuffer success.');
- file.readArrayBuffer({
- uri: 'internal://cache/../cache/File_writeArrayBuffer_010',
- success: function (data) {
- console.info('File_writeArrayBuffer_010 call readArrayBuffer pass');
- done();
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_010 readArrayBuffer fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_010 writeArrayBuffer fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_writeArrayBuffer_1200
- * @tc.name File_writeArrayBuffer_012
- * @tc.desc Function of API, out of package, Virtual path, save the dir authority.The test file is exist.
- */
- it('File_writeArrayBuffer_012', 0, async function (done) {
- let buf = new Uint8Array([48, 49, 50, 51, 65, 66, 67, 68, 32, 33]);
- file.writeArrayBuffer({
- uri: 'internal://app/notdir/File_writeArrayBuffer_012',
- buffer: buf,
- append: true,
- success: function () {
- console.info('File_writeArrayBuffer_012 => pass');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_writeArrayBuffer_012 , code: ' + code + ', data: ' + data);
- expect(code == 300).assertTrue();
- done();
- },
- complete: function () {
- console.info('writeArrayBuffer completed');
- }
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_readText_0100
- * @tc.name File_readText_001
- * @tc.desc Function of API, readText, app path.
- */
- it('File_readText_001', 0, async function (done) {
- file.writeText({
- uri: 'internal://cache/File_readText_001',
- text: 'Text that just for test.',
- success: function () {
- console.info('File_readText_001 call writeText success.');
- file.readText({
- uri: 'internal://cache/File_readText_001',
- success: function (data) {
- console.info('File_readText_001 call readText success.');
- done();
- },
- fail: function (data, code) {
- console.info('File_readText_001 readText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_readText_001 writeText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_readText_0200
- * @tc.name File_readText_002
- * @tc.desc Function of API, encoding = UTF-8.The test file is exist.
- */
- it('File_readText_002', 0, async function (done) {
- file.writeText({
- uri: 'internal://cache/File_readText_002',
- text: 'Text that just for test.',
- encoding: 'utf-8',
- success: function () {
- console.info('File_readText_002 call writeText success.');
- file.readText({
- uri: 'internal://cache/File_readText_002',
- encoding: 'utf-8',
- success: function (data) {
- console.info('File_readText_002 call readText success.');
- done();
- },
- fail: function (data, code) {
- console.info('File_readText_002 readText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_readText_002 writeText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_readText_0300
- * @tc.name File_readText_003
- * @tc.desc Function of API, error code: 202.The test file and dir is exist.
- */
- it('File_readText_003', 0, async function (done) {
- file.readText({
- uri: '',
- success: function (data) {
- console.info(data.text);
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_readText_003 , code: ' + code + ', data: ' + data);
- expect(code == 202).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_readText_0400
- * @tc.name File_readText_004
- * @tc.desc Function of API, error code: 300.The test dir is exist.
- */
- it('File_readText_004', 0, async function (done) {
- file.readText({
- uri: 'internal://cache/',
- success: function (data) {
- console.info(data.text);
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_readText_004 , code: ' + code + ', data: ' + data);
- expect(code == 300).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_readText_0500
- * @tc.name File_readText_005
- * @tc.desc Function of API, error code: 301.The test file and dir is exist.
- */
- it('File_readText_005', 0, async function (done) {
- file.readText({
- uri: 'internal://cache/workspace/text.txt',
- success: function (data) {
- console.info(data.text);
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_readText_005 , code: ' + code + ', data: ' + data);
- expect(code == 301).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_readText_0600
- * @tc.name File_readText_006
- * @tc.desc Function of API, readText, cache path.
- */
- it('File_readText_006', 0, async function (done) {
- file.writeText({
- uri: 'internal://cache/File_readText_006',
- text: 'test',
- success: function () {
- console.info('File_readText_006 call success');
- file.readText({
- uri: 'internal://cache/File_readText_006',
- success: function (data) {
- console.info('File_readText_006 call success' );
- file.delete({
- uri: 'internal://cache/File_readText_006',
- success: function () {
- console.info('File_readText_006 call success');
- done();
- },
- fail: function (data, code) {
- console.info('File_readText_006 delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_readText_006 readText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_readText_006 writeText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_readText_0700
- * @tc.name File_readText_007
- * @tc.desc Function of API, virtual path.The test file is exist.
- */
- it('File_readText_007', 0, async function (done) {
- file.writeText({
- uri: 'internal://cache/../files/../files/File_readText_007',
- text: 'Text that just for test.',
- success: function () {
- console.info('File_readText_007 call writeText success.');
- file.readText({
- uri: 'internal://cache/../files/../files/File_readText_007',
- success: function (data) {
- console.info('File_readText_007 call readText success. data.text:' );
- file.delete({
- uri: 'internal://cache/../files/../files/File_readText_007',
- success: function () {
- console.info('File_readText_007 call delete success');
- done();
- },
- fail: function (data, code) {
- console.info('File_readText_007 delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_readText_007 readText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_readText_007 writeText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_readText_0800
- * @tc.name File_readText_008
- * @tc.desc Function of API, virtual path.Test whether the files returned are equal.
- */
- it("File_readText_008", 0, async function (done) {
- let fpath = await nextFileName("File_readText_008");
- let text = "0123456789abcdefg";
- expect(prepareFile(fpath, text)).assertTrue();
- sleep(10);
- try {
- file.readText({
- uri: "internal://cache/File_readText_008",
- success: function (data) {
- console.info("call readText success: " + data.text);
- expect(text == data.text).assertTrue();
- fileio.unlinkSync(fpath);
- done();
- },
- fail: function (data, code) {
- console.error("call fail callback fail, code: " + code + ", data: " + data);
- expect(null).assertFail();
- },
- complete: function () {
- console.info('readText completed');
- }
- });
- } catch (e) {
- console.info("File_readText_008 has failed for " + e);
- expect(null).assertFail();
- }
- });
-
- /**
- * @tc.number SUB_STORAGE_File_read_array_buffer_0100
- * @tc.name File_read_array_buffer_001
- * @tc.desc Function of API, readArrayBuffer, cache path.position = 0, length = 10.
- */
- it('File_read_array_buffer_001', 0, async function (done) {
- var buffer = new Uint8Array([48, 49, 50, 51, 65, 66, 67, 68, 32, 33]);
- file.writeArrayBuffer({
- uri: 'internal://cache/File_read_array_buffer_001',
- buffer: buffer,
- success: function () {
- console.info('File_read_array_buffer_001 call writeArrayBuffer success.');
- file.readArrayBuffer({
- uri: 'internal://cache/File_read_array_buffer_001',
- position: 0,
- length: 10,
- success: function (data) {
- console.info('File_read_array_buffer_001 call readArrayBuffer pass');
- file.delete({
- uri: 'internal://cache/File_read_array_buffer_001',
- success: function () {
- console.info('File_read_array_buffer_001 call delete success');
- done();
- },
- fail: function (data, code) {
- console.info('File_read_array_buffer_001 delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_read_array_buffer_001 readArrayBuffer fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_read_array_buffer_001 writeArrayBuffer fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_read_array_buffer_0200
- * @tc.name File_read_array_buffer_002
- * @tc.desc Function of API, readArrayBuffer,
- */
- it('File_read_array_buffer_002', 0, async function (done) {
- var buffer = new Uint8Array([48, 49, 50, 51, 65, 66, 67, 68, 32, 33]);
- file.writeArrayBuffer({
- uri: 'internal://cache/File_read_array_buffer_002',
- buffer: buffer,
- success: function () {
- console.info('File_read_array_buffer_002 call writeArrayBuffer success.');
- file.readArrayBuffer({
- uri: 'internal://cache/File_read_array_buffer_002',
- success: function (data) {
- console.info('File_read_array_buffer_002 call readArrayBuffer pass');
- done();
- },
- fail: function (data, code) {
- console.info('File_read_array_buffer_002 readArrayBuffer fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_read_array_buffer_002 writeArrayBuffer fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_read_array_buffer_0300
- * @tc.name File_read_array_buffer_003
- * @tc.desc Function of API, readArrayBuffer, wrong uri.
- */
- it('File_read_array_buffer_003', 0, async function (done) {
- file.readArrayBuffer({
- uri: '',
- success: function (data) {
- console.info('File_read_array_buffer_003 call readArrayBuffer success: ' );
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_read_array_buffer_003 , code: ' + code + ', data: ' + data);
- expect(code == 202).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_read_array_buffer_0400
- * @tc.name File_read_array_buffer_004
- * @tc.desc Function of API, readArrayBuffer, wrong position.
- */
- it('File_read_array_buffer_004', 0, async function (done) {
- let fpath = await fileName('File_read_array_buffer_004');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- file.readArrayBuffer({
- uri: fpath,
- position: 100,
- success: function (data) {
- console.info('File_read_array_buffer_004 call readArrayBuffer success: ' );
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_read_array_buffer_004 , code: ' + code + ', data: ' + data);
- expect(code == 202).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_read_array_buffer_0500
- * @tc.name File_read_array_buffer_005
- * @tc.desc Function of API, readArrayBuffer, wrong length.
- */
- it('File_read_array_buffer_005', 0, async function (done) {
- let fpath = await fileName('File_read_array_buffer_005');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- file.readArrayBuffer({
- uri: fpath,
- length: -1,
- success: function (data) {
- console.info('File_read_array_buffer_005 call readArrayBuffer success: ' );
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_read_array_buffer_005 , code: ' + code + ', data: ' + data);
- expect(code == 202).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_read_array_buffer_0600
- * @tc.name File_read_array_buffer_006
- * @tc.desc Function of API, error code: 202 Set uri is dir path.
- */
- it('File_read_array_buffer_006', 0, async function (done) {
- file.readArrayBuffer({
- uri: 'internal://app',
- success: function (data) {
- console.info('File_read_array_buffer_006 call readArrayBuffer success: ' );
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_read_array_buffer_006 , code: ' + code + ', data: ' + data);
- expect(code == 202).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_read_array_buffer_0700
- * @tc.name File_read_array_buffer_007
- * @tc.desc Function of API, error code: 301
- */
- it('File_read_array_buffer_007', 0, async function (done) {
- file.readArrayBuffer({
- uri: 'internal://cache/File_read_array_buffer_007',
- success: function (data) {
- console.info('File_read_array_buffer_007 call readArrayBuffer success: ' );
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_read_array_buffer_007 , code: ' + code + ', data: ' + data);
- expect(code == 301).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_read_array_buffer_0800
- * @tc.name File_read_array_buffer_008
- * @tc.desc Function of API, cache path.The test file is exist.
- */
- it('File_read_array_buffer_008', 0, async function (done) {
- let buf = new Uint8Array([1, 2, 3, 4, 5, 6, 7, 8]);
- file.writeArrayBuffer({
- uri: 'internal://cache/File_read_array_buffer_008',
- buffer: buf,
- success: function () {
- console.info('File_read_array_buffer_008 call writeArrayBuffer success');
- file.readArrayBuffer({
- uri: 'internal://cache/File_read_array_buffer_008',
- success: function (data) {
- console.info('File_read_array_buffer_008 call readArrayBuffer success ' );
- file.delete({
- uri: 'internal://cache/File_read_array_buffer_008',
- success: function () {
- console.info('File_read_array_buffer_008 call delete success');
- done();
- },
- fail: function (data, code) {
- console.info('File_read_array_buffer_008 delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_read_array_buffer_008 readArrayBuffer fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_read_array_buffer_008 writeArrayBuffer fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_read_array_buffer_0900
- * @tc.name File_read_array_buffer_009
- * @tc.desc Function of API, virtual path.The test file is exist.
- */
- it('File_read_array_buffer_009', 0, async function (done) {
- var buffer = new Uint8Array([48, 49, 50, 51, 65, 66, 67, 68, 32, 33]);
- file.writeArrayBuffer({
- uri: 'internal://cache/../cache/File_read_array_buffer_009',
- buffer: buffer,
- success: function () {
- console.info('File_read_array_buffer_009 call writeArrayBuffer success.');
- file.readArrayBuffer({
- uri: 'internal://cache/../cache/File_read_array_buffer_009',
- position: 0,
- length: 10,
- success: function (data) {
- console.info('File_read_array_buffer_009 call readArrayBuffer success. data.buffer:' );
- file.delete({
- uri: 'internal://cache/../cache/File_read_array_buffer_009',
- success: function () {
- console.info('File_read_array_buffer_009 call delete success');
- done();
- },
- fail: function (data, code) {
- console.info('File_read_array_buffer_009 delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_read_array_buffer_009 readArrayBuffer fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- complete: function () {
- console.info('readArrayBuffer completed');
- }
- });
- },
- fail: function (data, code) {
- console.info('File_read_array_buffer_009 writeArrayBuffer fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_access_0100
- * @tc.name File_access_001
- * @tc.desc Function of API, access, cache path.The test file is exist.
- */
- it('File_access_001', 0, async function (done) {
- file.writeText({
- uri: 'internal://cache/File_access_001',
- text: 'Text that just for test.',
- success: function () {
- console.info('File_access_001 call writeText success.');
- file.access({
- uri: 'internal://cache/File_access_001',
- success: function () {
- console.info('File_access_001 call access success.');
- file.delete({
- uri: 'internal://cache/File_access_001',
- success: function () {
- console.info('File_access_001 call delete success.');
- done();
- },
- fail: function (data, code) {
- console.info('File_access_001 delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_access_001 access fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_access_001 writeText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_access_0200
- * @tc.name File_access_002
- * @tc.desc Function of API, access, app path.The test file is exist.
- */
- it('File_access_002', 0, async function (done) {
- file.mkdir({
- uri: 'internal://cache/File_access_002',
- success: function () {
- console.info('File_access_002 call mkdir success.');
- file.access({
- uri: 'internal://cache/File_access_002',
- success: function () {
- console.info('File_access_002 call access success.');
- file.rmdir({
- uri: 'internal://cache/File_access_002',
- success: function () {
- console.info('File_access_002 call rmdir success.');
- done();
- },
- fail: function (data, code) {
- console.info('File_access_002 rmdir fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_access_002 access fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_access_002 mkdir fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_access_0300
- * @tc.name File_access_003
- * @tc.desc Function of API, error code: 202 The test file and dir are exist.
- */
- it('File_access_003', 0, async function (done) {
- let fpath = await fileName('File_access_003');
- file.access({
- uri: fpath,
- success: function () {
- console.info('File_access_003 call access success.');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_access_003 , code: ' + code + ', data: ' + data);
- expect(code == 202).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_access_0400
- * @tc.name File_access_004
- * @tc.desc Function of API, error code: 301
- */
- it('File_access_004', 0, async function (done) {
- file.access({
- uri: 'internal://app/File_access_004.txt',
- success: function () {
- console.info('File_access_004 call access success.');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_access_004 , code: ' + code + ', data: ' + data);
- expect(code == 301).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_access_0500
- * @tc.name File_access_005
- * @tc.desc Function of API, error code: 301
- */
- it('File_access_005', 0, async function (done) {
- file.access({
- uri: 'internal://app/File_access_005',
- success: function () {
- console.info('File_access_005 call access success.');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_access_005 , code: ' + code + ', data: ' + data);
- expect(code == 301).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_access_0600
- * @tc.name File_access_006
- * @tc.desc Function of API, parameter more than 4096.The test file and dir are exist.
- */
- it('File_access_006', 0, async function (done) {
- let firstPath = randomString(32);
- let dpath = await fileName(firstPath);
- let uri = 'internal://cache/' + firstPath;
- fileio.mkdirSync(dpath);
- for (let i = 0; i < 16; i++) {
- console.info('time' + i);
- let sonPath = randomString(251);
- uri = uri + '/f' + sonPath;
- }
- file.access({
- uri: uri,
- success: function () {
- console.info('File_access_006 => pass');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_access_006 , code: ' + code + ', data: ' + data);
- expect(code == 300).assertTrue();
- fileio.rmdirSync(dpath);
- done();
- },
- });
-
- });
-
- /**
- * @tc.number SUB_STORAGE_File_access_0700
- * @tc.name File_access_007
- * @tc.desc Function of API, app path.The test file is exist.
- */
- it('File_access_007', 0, async function (done) {
- file.writeText({
- uri: 'internal://cache/File_access_007',
- text: 'hello',
- success: function () {
- console.info('File_access_007 writeText success ');
- file.access({
- uri: 'internal://cache/File_access_007',
- success: function () {
- console.info('File_access_007 access success');
- file.delete({
- uri: 'internal://cache/File_access_007',
- success: function () {
- console.info('File_access_007 delete success');
- done();
- },
- fail: function (data, code) {
- console.info('File_access_007 delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_access_007 access fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_access_007 writeText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_access_0800
- * @tc.name File_access_008
- * @tc.desc Function of API, virtual path.The test file is exist.
- */
- it('File_access_008', 0, async function (done) {
- file.writeText({
- uri: 'internal://cache/../cache/File_access_008',
- text: 'Text that just for test.',
- success: function () {
- console.info('File_access_008 writeText success.');
- file.access({
- uri: 'internal://cache/../cache/File_access_008',
- success: function () {
- console.info('File_access_008 call access success.');
- file.delete({
- uri: 'internal://cache/../cache/File_access_008',
- success: function () {
- console.info('File_access_008 call delete success.');
- done();
- },
- fail: function (data, code) {
- console.info('File_access_008 delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- }
- });
- },
- fail: function (data, code) {
- console.info('File_access_008 access fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- complete: function () {
- console.info('access completed');
- }
- });
- },
- fail: function (data, code) {
- console.info('File_access_008 writeText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_mkdir_0100
- * @tc.name File_mkdir_001
- * @tc.desc Function of API, mkdir, app path.
- */
- it('File_mkdir_001', 0, async function (done) {
- file.mkdir({
- uri: 'internal://cache/File_mkdir_001',
- success: function () {
- console.info('File_mkdir_001 call mkdir success.');
- file.rmdir({
- uri: 'internal://cache/File_mkdir_001',
- success: function () {
- console.info('File_mkdir_001 call rmdir success.');
- done();
- },
- fail: function (data, code) {
- console.info('File_mkdir_001 rmdir fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_mkdir_001 mkdir fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_mkdir_0200
- * @tc.name File_mkdir_002
- * @tc.desc Function of API, mkdir, recursive not set value.
- */
- it('File_mkdir_002', 0, async function (done) {
- file.mkdir({
- uri: 'internal://app/test/File_mkdir_002',
- success: function () {
- console.info('File_mkdir_002 call mkdir success.');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_mkdir_002 , code: ' + code + ', data: ' + data);
- expect(code == 300).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_mkdir_0300
- * @tc.name File_mkdir_003
- * @tc.desc Function of API, mkdir, recursive.
- */
- it('File_mkdir_003', 0, async function (done) {
- file.mkdir({
- uri: 'internal://cache/test/File_mkdir_003d',
- recursive: true,
- success: function () {
- console.info('File_mkdir_003 call mkdir success.');
- done();
- },
- fail: function (data, code) {
- console.info('File_mkdir_003 , code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_mkdir_0400
- * @tc.name File_mkdir_004
- * @tc.desc Function of API, error code: 202
- */
- it('File_mkdir_004', 0, async function (done) {
- file.mkdir({
- uri: 'internal://files/test/File_mkdir_002d',
- success: function () {
- console.info('File_mkdir_004 call mkdir success.');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_mkdir_004, code: ' + code + ', data: ' + data);
- expect(code == 202).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_mkdir_0500
- * @tc.name File_mkdir_005
- * @tc.desc Function of API, special characters.
- */
- it('File_mkdir_005', 0, async function (done) {
- file.mkdir({
- uri: 'internal://cache/!@/<>',
- success: function () {
- console.info('File_mkdir_005 mkdir success');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_mkdir_005 fail, code: ' + code + ', data: ' + data);
- expect(code == 300).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_mkdir_0600
- * @tc.name File_mkdir_006
- * @tc.desc Function of API, parameter too long.
- */
- it('File_mkdir_006', 0, async function (done) {
- let fileName = randomString(257);
- file.mkdir({
- uri: 'internal://cache/' + fileName,
- success: function () {
- console.info('File_mkdir_006 mkdir success');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_mkdir_006 =>fail ,code:' + code + ',data: ' + data);
- expect(code == 300).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_mkdir_0700
- * @tc.name File_mkdir_007
- * @tc.desc Function of API, cache path.
- */
- it('File_mkdir_007', 0, async function (done) {
- file.mkdir({
- uri: 'internal://cache/File_mkdir_007d',
- success: function () {
- console.info('File_mkdir_007 mkdir success');
- file.rmdir({
- uri: 'internal://cache/File_mkdir_007d',
- success: function () {
- console.info('File_mkdir_007 delete success');
- done();
- },
- fail: function (data, code) {
- console.info('File_mkdir_007 delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_mkdir_007 mkdir fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_mkdir_0800
- * @tc.name File_mkdir_008
- * @tc.desc Function of API, virtual path.
- */
- it('File_mkdir_008', 0, async function (done) {
- file.mkdir({
- uri: 'internal://cache/../files/File_mkdir_008',
- success: function () {
- console.info('File_mkdir_008 call mkdir success.');
- file.rmdir({
- uri: 'internal://cache/../files/File_mkdir_008',
- success: function () {
- console.info('File_mkdir_008 call rmdir success.');
- done();
- },
- fail: function (data, code) {
- console.info('File_mkdir_008 rmdir fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_mkdir_008 mkdir fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_mkdir_1000
- * @tc.name File_mkdir_010
- * @tc.desc Function of API, out of package, out of package, Virtual path, save the dir authority.
- */
- it('File_mkdir_010', 0, async function (done) {
- file.mkdir({
- uri: 'internal://app/notdir/File_mkdir_010',
- success: function () {
- console.info('File_mkdir_010 call mkdir success.');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_mkdir_010 call mkdir callback fail, code: ' + code + ', data: ' + data);
- expect(code == 300).assertTrue();
- done();
- },
- complete: function () {
- console.info('mkdir completed');
- }
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_rmdir_0100
- * @tc.name File_rmdir_001
- * @tc.desc Function of API, rmdir, app path.The test dir is exist, and it can be delete, the dir is empty.
- */
- it('File_rmdir_001', 0, async function (done) {
- file.mkdir({
- uri: 'internal://cache/File_rmdir_001',
- success: function () {
- console.info('File_rmdir_001 call mkdir success.');
- file.rmdir({
- uri: 'internal://cache/File_rmdir_001',
- success: function () {
- console.info('File_rmdir_001 call rmdir success.');
- done();
- },
- fail: function (data, code) {
- console.info('File_rmdir_001 rmdir fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_rmdir_001 mkdir fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_rmdir_0200
- * @tc.name File_rmdir_002
- * @tc.desc Function of API, recursive not set value.The test dir is exist, and it not empty.
- */
- it('File_rmdir_002', 0, async function (done) {
- file.mkdir({
- uri: 'internal://app/test/File_rmdir_002',
- recursive: true,
- success: function () {
- console.info('File_rmdir_002 mkdir success.');
- file.rmdir({
- uri: 'internal://app/test',
- recursive: false,
- success: function () {
- console.info('File_rmdir_002 call rmdir success.');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_rmdir_002 fail, code: ' + code + ', data: ' + data);
- expect(code == 301 || code == 300).assertTrue();
- done();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_rmdir_002 fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_rmdir_0300
- * @tc.name File_rmdir_003
- * @tc.desc Function of API, recursive = ture.The test dir is exist, and it not empty.
- */
- it('File_rmdir_003', 0, async function (done) {
- file.mkdir({
- uri: 'internal://cache/test/File_rmdir_003/File_rmdir_003_1/File_rmdir_003_2',
- recursive: true,
- success: function () {
- console.info('File_rmdir_003 mkdir success.');
- file.mkdir({
- uri: 'internal://cache/test/File_rmdir_003_1/File_rmdir_003_1/File_rmdir_003_2',
- recursive: true,
- success: function () {
- console.info('File_rmdir_003 mkdir success.');
- file.mkdir({
- uri: 'internal://cache/test/File_rmdir_003_2/File_rmdir_003_1/File_rmdir_003_2',
- recursive: true,
- success: function () {
- console.info('File_rmdir_003 mkdir success.');
- file.rmdir({
- uri: 'internal://cache/test',
- recursive: true,
- success: function () {
- console.info('File_rmdir_003 call rmdir success.');
- done();
- },
- fail: function (data, code) {
- console.info('File_rmdir_003 , code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_rmdir_003 fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_rmdir_003 fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_rmdir_003 fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_rmdir_0400
- * @tc.name File_rmdir_004
- * @tc.desc Function of API, error code: 202
- */
- it('File_rmdir_004', 0, async function (done) {
- file.rmdir({
- uri: '/data/accounts/account_0/appdata/ohos.acts.distributeddatamgr.distributedfile/cache/',
- success: function () {
- console.info('File_rmdir_004 call rmdir success.');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_rmdir_004 , code: ' + code + ', data: ' + data);
- expect(code == 202).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_rmdir_0500
- * @tc.name File_rmdir_005
- * @tc.desc Function of API, error code: 301
- */
- it('File_rmdir_005', 0, async function (done) {
- file.rmdir({
- uri: 'internal://app/123',
- success: function () {
- console.info('File_rmdir_005 call rmdir success.');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_rmdir_005 rmdir fail, code: ' + code + ', data: ' + data);
- expect(code == 301).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_rmdir_0600
- * @tc.name File_rmdir_006
- * @tc.desc Function of API, too long path.
- */
- it('File_rmdir_006', 0, async function (done) {
- let firstPath = randomString(255);
- let uri = 'internal://cache/' + firstPath;
- file.mkdir({
- uri: uri,
- success: function () {
- console.info('File_rmdir_006 mkdir success');
- file.rmdir({
- uri: uri,
- success: function () {
- console.info('File_rmdir_006 rmdir success');
- done();
- },
- fail: function (data, code) {
- console.info('File_rmdir_006 rmdir fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_rmdir_006 mkdir fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_rmdir_0700
- * @tc.name File_rmdir_007
- * @tc.desc Function of API, cache path.The test dir is exist, and it can be delete, it is empty.
- */
- it('File_rmdir_007', 0, async function (done) {
- file.mkdir({
- uri: 'internal://cache/File_rmdir_007d',
- success: function () {
- console.info('File_rmdir_007 mkdir success');
- file.rmdir({
- uri: 'internal://cache/File_rmdir_007d',
- success: function () {
- console.info('File_rmdir_007 rmdir success');
- done();
- },
- fail: function (data, code) {
- console.info('File_rmdir_007 rmdir fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_rmdir_007 mkdir fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_rmdir_0800
- * @tc.name File_rmdir_008
- * @tc.desc Function of API, virtual path.The test dir is exist.
- */
- it('File_rmdir_008', 0, async function (done) {
- file.mkdir({
- uri: 'internal://cache/../files/File_rmdir_008',
- success: function () {
- console.info('File_rmdir_008 call mkdir success.');
- file.rmdir({
- uri: 'internal://cache/../files/File_rmdir_008',
- success: function () {
- console.info('File_rmdir_008 call rmdir success.');
- done();
- },
- fail: function (data, code) {
- console.info('File_rmdir_008 rmdir fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_rmdir_008 mkdir fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_rmdir_1000
- * @tc.name File_rmdir_010
- * @tc.desc Function of API, out of package, Virtual path, save the dir authority.The test dir is exist.
- */
- it('File_rmdir_010', 0, async function (done) {
- file.rmdir({
- uri: 'internal://app/../../com.ohos.systemui',
- success: function () {
- console.info('File_rmdir_010 call rmdir success.');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_rmdir_010 call rmdir callback fail, code: ' + code + ', data: ' + data);
- expect(code == 301).assertTrue();
- done();
- },
- complete: function () {
- console.info('rmdir completed');
- }
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Move_0100
- * @tc.name File_Move_001
- * @tc.desc Function of API, move.The test file is exist.
- */
- it('File_Move_001', 0, async function (done) {
- file.writeText({
- uri: 'internal://cache/File_Move_001',
- text: 'Text that just for test.',
- success: function () {
- console.info('File_Move_001 call writeText success.');
- file.move({
- srcUri: 'internal://cache/File_Move_001',
- dstUri: 'internal://cache/File_Move_001_1',
- success: function (data) {
- console.info('File_Move_001 call writeText success. data:' + data);
- done();
- },
- fail: function (data, code) {
- console.info('File_Move_001 move fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.error('File_Move_001 call writeText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Move_0200
- * @tc.name File_Move_002
- * @tc.desc Function of API, document integrity.The test file is exist.
- */
- it('File_Move_002', 0, async function (done) {
- let typeArray = new Array('.txt', '.ppt', '.flac', '.mp4', '.so', '.zip');
- let dpath = await fileName('cache');
- fileio.mkdirSync(dpath);
- for (let i = 0; i < typeArray.length; i++) {
- let srcFpath = await fileName('File_Move_002') + typeArray[i];
- let dstFpath = await cacheFileName('File_Move_002') + typeArray[i];
- expect(prepareEmptyFile(srcFpath)).assertTrue();
- file.move({
- srcUri: 'internal://cache/../files/File_Move_002' + typeArray[i],
- dstUri: 'internal://cache/../files/cache/File_Move_002' + typeArray[i],
- success: function (uri) {
- console.info('File_Move_002 call move success. uri: ' + uri);
- done();
- },
- fail: function (data, code) {
- console.info('File_Move_002 , code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- }
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Move_0300
- * @tc.name File_Move_003
- * @tc.desc Function of API, different size file.The test file is exist.
- */
- it('File_Move_003', 0, async function (done) {
- let srcFpath = await fileName('File_Move_003');
- expect(prepareFile(srcFpath, FILE_CONTENT)).assertTrue();
- let dstFpath = await cacheFileName('File_Move_003');
- let srcUri = 'internal://cache/../files/File_Move_003';
- let dstUri = 'internal://app/cache/File_Move_003';
- file.move({
- srcUri: srcUri,
- dstUri: dstUri,
- success: function () {
- console.info('File_Move_003 call move success.');
- done();
- },
- fail: function (data, code) {
- console.info('File_Move_003 , code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Move_0400
- * @tc.name File_Move_004
- * @tc.desc Function of API, error code: 202.The test file is exist.
- */
- it('File_Move_004', 0, async function (done) {
- let srcFpath = await fileName('File_Move_004');
- expect(prepareFile(srcFpath, FILE_CONTENT)).assertTrue();
- file.move({
- srcUri: 'internal://app/File_Move_004',
- dstUri: null,
- success: function () {
- console.info('File_Move_004 call move success.');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_Move_004 , code: ' + code + ', data: ' + data);
- expect(code == 202).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Move_0500
- * @tc.name File_Move_005
- * @tc.desc Function of API, error code: 300.The test file is exist.
- */
- it('File_Move_005', 0, async function (done) {
- let srcDpath = await fileName('File_Move_005d');
- fileio.mkdirSync(srcDpath);
- file.move({
- srcUri: 'internal://cache/../files/File_Move_005d',
- dstUri: 'internal://app/cache/File_Move_005d',
- success: function () {
- console.info('File_Move_005 call move success.');
- done();
- },
- fail: function (data, code) {
- console.info('File_Move_005 , code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Move_0600
- * @tc.name File_Move_006
- * @tc.desc Function of API, error code: 301.The test file is not exist.
- */
- it('File_Move_006', 0, async function (done) {
- let dstUri = await fileName('File_Move_006');
- expect(prepareFile(dstUri, FILE_CONTENT)).assertTrue();
- file.move({
- srcUri: 'internal://app/File_Move',
- dstUri: 'internal://app/File_Move_006',
- success: function () {
- console.info('File_Move_006 call move success.');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_Move_006 , code: ' + code + ', data: ' + data);
- expect(code == 301).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Move_0700
- * @tc.name File_Move_007
- * @tc.desc Function of API, uri more too long.
- */
- it('File_Move_007', 0, async function (done) {
- let firstPath = randomString(32);
- let dpath = await fileName(firstPath);
- let uri = 'internal://app/' + firstPath;
- fileio.mkdirSync(dpath);
- for (let i = 0; i < 16; i++) {
- console.info('time' + i);
- let sonPath = randomString(251);
- uri = uri + '/f' + sonPath;
- }
- file.move({
- srcUri: uri,
- dstUri: 'internal://cache/File_Move_007',
- success: function () {
- console.info('File_Move_007 => move success');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_Move_007 => move fail');
- expect(code == 300).assertTrue();
- done();
- },
- });
- fileio.rmdirSync(dpath);
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Move_0800
- * @tc.name File_Move_008
- * @tc.desc Function of API, cache path.The test file is exist.
- */
- it('File_Move_008', 0, async function (done) {
- file.writeText({
- uri: 'internal://cache/File_Move_008',
- text: 'sss',
- success: function () {
- console.info('File_Move_008 writeText success ');
- file.move({
- srcUri: 'internal://cache/File_Move_008',
- dstUri: 'internal://app/File_Move_008',
- success: function (uri) {
- console.info('File_Move_008 move pass, uri:' + uri);
- file.delete({
- uri: 'internal://app/File_Move_008',
- success: function () {
- console.info('File_Move_008 delete success');
- done();
- },
- fail: function (data, code) {
- console.info('File_Move_008 delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_Move_008 move fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_Move_008 writeText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Move_0900
- * @tc.name File_Move_009
- * @tc.desc Function of API, same path.
- */
- it('File_Move_009', 0, async function (done) {
- let srcFpath = await fileName('File_Move_009');
- expect(prepareFile(srcFpath, FILE_CONTENT)).assertTrue();
- file.move({
- srcUri: 'internal://app/File_Move_009',
- dstUri: 'internal://app/File_Move_009',
- success: function (data) {
- console.info('File_Move_009 => pass');
- done();
- },
- fail: function (data, code) {
- console.info('File_Move_009 call move fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Move_1000
- * @tc.name File_Move_010
- * @tc.desc Function of API, dstFpath has same file.
- */
- it('File_Move_010', 0, async function (done) {
- let srcFpath = await fileName('File_Move_010');
- let dstFpath = await cacheFileName('File_Move_010');
- expect(prepareFile(srcFpath, 'aaa')).assertTrue();
- expect(prepareFile(dstFpath, 'bbb')).assertTrue();
- file.move({
- srcUri: 'internal://app/File_Move_010',
- dstUri: 'internal://app/cache/File_Move_010',
- success: function (data) {
- console.info('File_Move_010 => pass');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_Move_010 , code: ' + code + ', data: ' + data);
- expect(code == 300).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Move_1100
- * @tc.name File_Move_011
- * @tc.desc Function of API, move app path file to cache path.
- */
- it('File_Move_011', 0, async function (done) {
- let srcFpath = await fileName('File_Move_011');
- expect(prepareFile(srcFpath, FILE_CONTENT)).assertTrue();
- file.move({
- srcUri: 'internal://cache/../files/File_Move_011',
- dstUri: 'internal://cache/File_Move_011',
- success: function (uri) {
- console.info('File_Move_011 => pass, uri' + uri);
- done();
- },
- fail: function (data, code) {
- console.info('File_Move_011 , code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Move_1200
- * @tc.name File_Move_012
- * @tc.desc Function of API, out of package, Virtual path(create and give 777 authority).
- */
- it('File_Move_012', 0, async function (done) {
- let srcFpath = await fileName('File_Move_012');
- expect(prepareFile(srcFpath, FILE_CONTENT)).assertTrue();
- file.move({
- srcUri: 'internal://app/../files/File_Move_012',
- dstUri: 'internal://app/notdir/File_Move_012',
- success: function (uri) {
- console.info('File_Move_012 => pass, uri' + uri);
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_Move_012 , code: ' + code + ', data: ' + data);
- expect(code == 300).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Move_1400
- * @tc.name File_Move_014
- * @tc.desc Function of API, check back value.
- */
- it('File_Move_014', 0, async function (done) {
- let srcFpath = await fileName('File_Move_014');
- let dstFpath = await cacheFileName('File_Move_014');
- expect(prepareFile(srcFpath, 'test')).assertTrue();
- let dstUri = 'internal://cache/File_Move_014';
- file.move({
- srcUri: 'internal://cache/../files/File_Move_014',
- dstUri: dstUri,
- success: function (uri) {
- console.info('File_Move_014 move pass');
- done();
- },
- fail: function (data, code) {
- console.info('File_Move_014 => fail , code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- complete: function () {
- console.info('move completed');
- }
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Copy_0100
- * @tc.name File_Copy_001
- * @tc.desc Function of API, copy, app path.The test file is exist.
- */
- it('File_Copy_001', 0, async function (done) {
- let srcFpath = await fileName('File_Copy_001');
- let dstFpath = await cacheFileName('File_Copy_001');
- expect(prepareFile(srcFpath, 'test.')).assertTrue();
- file.copy({
- srcUri: 'internal://cache/../files/File_Copy_001',
- dstUri: 'internal://cache/../files/cache/File_Copy_001',
- success: function () {
- console.info('File_Copy_001 call copy success.');
- file.readText({
- uri: 'internal://cache/../files/cache/File_Copy_001',
- success: function (data) {
- console.info('File_Copy_001 read success:' );
- fileio.unlinkSync(srcFpath);
- fileio.unlinkSync(dstFpath);
- done();
- },
- fail: function (data, code) {
- console.info('File_Copy_001 readText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_Copy_001 copy fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Copy_0200
- * @tc.name File_Copy_002
- * @tc.desc Function of API, document integrity.The test file is exist.
- */
- it('File_Copy_002', 0, async function (done) {
- let typeArray = new Array('.txt', '.ppt', '.flac', '.mp4', '.so', '.zip');
- for (let i = 0; i < typeArray.length; i++) {
- let srcFpath = await fileName('File_Copy_002') + typeArray[i];
- let dstFpath = await cacheFileName('File_Copy_002') + typeArray[i];
- expect(prepareEmptyFile(srcFpath)).assertTrue();
- file.copy({
- srcUri: 'internal://cache/../files/File_Copy_002' + typeArray[i],
- dstUri: 'internal://cache/../files/cache/File_Copy_002' + typeArray[i],
- success: function () {
- console.info('File_Copy_002 call copy success.');
- file.delete('internal://cache/../files/File_Copy_002' + typeArray[i]);
- file.delete('internal://cache/../files/cache/File_Copy_002' + typeArray[i]);
- done();
- },
- fail: function (data, code) {
- console.info('File_Copy_002 , code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- }
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Copy_0300
- * @tc.name File_Copy_003
- * @tc.desc Function of API, different size of files. The test file is exist.
- */
- it('File_Copy_003', 0, async function (done) {
- let srcFpath = await fileName('File_Copy_003');
- expect(prepareFile(srcFpath, FILE_CONTENT)).assertTrue();
- let dstFpath = await cacheFileName('File_Copy_003');
- file.copy({
- srcUri: 'internal://cache/../files/File_Copy_003',
- dstUri: 'internal://cache/../files/cache/File_Copy_003',
- success: function () {
- console.info('File_Copy_003 call copy success.');
- file.readText({
- uri: 'internal://cache/../files/cache/File_Copy_003',
- success: function (data) {
- console.info('File_Copy_003 readText success, data.text:');
- fileio.unlinkSync(srcFpath);
- fileio.unlinkSync(dstFpath);
- done();
- },
- fail: function (data, code) {
- console.info('File_Copy_003 readText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_Copy_003 copy fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Copy_0400
- * @tc.name File_Copy_004
- * @tc.desc Function of API, error code: 202 The test file is exist.
- */
- it('File_Copy_004', 0, async function (done) {
- let srcFpath = await fileName('File_Copy_004');
- expect(prepareFile(srcFpath, FILE_CONTENT)).assertTrue();
- file.copy({
- srcUri: 'internal://app/File_Copy_004',
- dstUri: null,
- success: function () {
- console.info('File_Copy_004 call copy success.');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_Copy_004 , code: ' + code + ', data: ' + data);
- expect(code == 202).assertTrue();
- fileio.unlinkSync(srcFpath);
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Copy_0500
- * @tc.name File_Copy_005
- * @tc.desc Function of API, error code: 300
- */
-
- it('File_Copy_005', 0, async function (done) {
- file.mkdir({
- uri: 'internal://cache/File_Copy_005d',
- success: function () {
- console.info('File_Copy_005 call mkdir success.');
- file.copy({
- srcUri: 'internal://cache/File_Copy_005d',
- dstUri: 'internal://cache/File_Copy_005d_1',
- success: function () {
- console.info('File_Copy_005 call copy success.');
- done();
- },
- fail: function (data, code) {
- console.info('File_Copy_005 , code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.error('File_Copy_005 call mkdir fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Copy_0600
- * @tc.name File_Copy_006
- * @tc.desc Function of API, error code: 301
- */
- it('File_Copy_006', 0, async function (done) {
- file.copy({
- srcUri: 'internal://app/fakepath',
- dstUri: 'internal://app/fakepath1',
- success: function () {
- console.info('File_Copy_006 call copy success.');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_Copy_006 , code: ' + code + ', data: ' + data);
- expect(code == 301).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Copy_0700
- * @tc.name File_Copy_007
- * @tc.desc Function of API, uri too long.
- */
- it('File_Copy_007', 0, async function (done) {
- let firstPath = randomString(32);
- let dpath = await fileName(firstPath);
- let uri = 'internal://cache/' + firstPath;
- fileio.mkdirSync(dpath);
- for (let i = 0; i < 16; i++) {
- console.info('time' + i);
- let sonPath = randomString(251);
- uri = uri + '/f' + sonPath;
- }
- file.copy({
- srcUri: uri,
- dstUri: uri,
- success: function () {
- console.info('File_Copy_007 => copy success');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_Copy_007 => fail, code: ' + code + ', data: ' + data);
- fileio.rmdirSync(dpath);
- expect(code == 300).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Copy_0800
- * @tc.name File_Copy_008
- * @tc.desc Function of API, cache path.
- */
- it('File_Copy_008', 0, async function (done) {
- file.writeText({
- uri: 'internal://cache/File_Copy_008',
- text: 'test',
- success: function () {
- console.info('File_Copy_008 mkdir success');
- file.copy({
- srcUri: 'internal://cache/File_Copy_008',
- dstUri: 'internal://cache/../files/File_Copy_008',
- success: function () {
- console.info('File_Copy_008 copy success');
- file.delete({
- uri: 'internal://cache/../files/File_Copy_008',
- success: function () {
- console.info('File_Copy_008 delete success ');
- file.delete({
- uri: 'internal://cache/File_Copy_008',
- success: function () {
- console.info('File_Copy_008 delete success');
- done();
- },
- fail: function (data, code) {
- console.info('File_Copy_008 cache delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_Copy_008 files delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_Copy_008 copy fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_Copy_008 writeText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Copy_0900
- * @tc.name File_Copy_009
- * @tc.desc Function of API, same path.
- */
- it('File_Copy_009', 0, async function (done) {
- let srcFpath = await fileName('File_Copy_009');
- expect(prepareFile(srcFpath, FILE_CONTENT)).assertTrue();
- file.copy({
- srcUri: 'internal://app/File_Copy_009',
- dstUri: 'internal://app/File_Copy_009',
- success: function (data) {
- console.info('File_Copy_009 => pass');
- fileio.unlinkSync(srcFpath);
- done();
- },
- fail: function (data, code) {
- console.info('File_Copy_009 , code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Copy_1000
- * @tc.name File_Copy_010
- * @tc.desc Function of API, dstFpath path has same file.
- */
- it('File_Copy_010', 0, async function (done) {
- let srcFpath = await fileName('File_Copy_010');
- let dstFpath = await cacheFileName('File_Copy_010');
- expect(prepareFile(srcFpath, 'aaa')).assertTrue();
- expect(prepareFile(dstFpath, 'bbb')).assertTrue();
- file.copy({
- srcUri: 'internal://app/File_Copy_010',
- dstUri: 'internal://app/cache/File_Copy_010',
- success: function (data) {
- console.info('File_Copy_010 => pass');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_Copy_010 , code: ' + code + ', data: ' + data);
- console.info("code::" + code);
- expect(code == 300).assertTrue();
- fileio.unlinkSync(srcFpath);
- fileio.unlinkSync(dstFpath);
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Copy_1100
- * @tc.name File_Copy_011
- * @tc.desc Function of API, copy file to cache path.The test file is exist.
- */
- it('File_Copy_011', 0, async function (done) {
- let srcFpath = await fileName('File_Copy_011');
- expect(prepareFile(srcFpath, 'test.')).assertTrue();
- file.copy({
- srcUri: 'internal://cache/../files/File_Copy_011',
- dstUri: 'internal://cache/File_Copy_011',
- success: function () {
- console.info('File_Copy_011 copy pass');
- file.readText({
- uri: 'internal://cache/File_Copy_011',
- success: function (data) {
- console.info('File_Copy_011 read success:' );
- done();
- },
- fail: function (data, code) {
- console.info('File_Copy_011 readText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_Copy_011 copy fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Copy_1200
- * @tc.name File_Copy_012
- * @tc.desc Function of API, out of package, Virtual path(create and give 777 authority).The test file is exist.
- */
- it('File_Copy_012', 0, async function (done) {
- let srcFpath = await fileName('File_Copy_012');
- expect(prepareFile(srcFpath, 'test')).assertTrue();
- file.copy({
- srcUri: 'internal://app/../files/File_Copy_012',
- dstUri: 'internal://app/notdir/File_Move_012',
- success: function () {
- console.info('File_Copy_012 copy pass');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_Copy_012 , code: ' + code + ', data: ' + data);
- expect(code == 300).assertTrue();
- fileio.unlinkSync(srcFpath);
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Copy_1400
- * @tc.name File_Copy_014
- * @tc.desc Function of API, check back value.The test file is exist.
- */
-
- it('File_Copy_014', 0, async function (done) {
- let srcFpath = await fileName('File_Copy_014');
- let dstFpath = await cacheFileName('File_Copy_014');
- expect(prepareFile(srcFpath, 'test')).assertTrue();
- let dstUri = 'internal://cache/File_Copy_014';
- file.copy({
- srcUri: 'internal://cache/../files/File_Copy_014',
- dstUri: dstUri,
- success: function (uri) {
- console.info('File_Copy_014 copy pass');
- done();
- },
- fail: function (data, code) {
- console.info('File_Copy_014 => fail , code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- complete: function () {
- console.info('copy completed');
- }
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_List_0100
- * @tc.name File_List_001
- * @tc.desc Function of API, list.The test file and dir are exist.
- */
- it('File_List_001', 0, async function (done) {
- let dpath = await fileName('File_List_001') + 'd';
- let fpath = dpath + '/File_List_001';
- let ddpath = dpath + '/File_List_001_1d';
- fileio.mkdirSync(dpath);
- fileio.mkdirSync(ddpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- file.list({
- uri: 'internal://cache/../files/File_List_001d',
- success: function (data) {
- console.info('File_List_001 call list success.' + JSON.stringify(data.fileList));
- fileio.unlinkSync(fpath);
- fileio.rmdirSync(ddpath);
- fileio.rmdirSync(dpath);
- done();
- },
- fail: function (data, code) {
- console.info('File_List_001 , code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_List_0200
- * @tc.name File_List_002
- * @tc.desc Function of API, set value of uri.The test file and dir are exist.
- */
- it('File_List_002', 0, async function (done) {
- let dpath = await fileName('File_List_002') + 'd';
- let fpath = dpath + '/File_List_002';
- let ddpath = dpath + '/File_List_002_1d';
- fileio.mkdirSync(dpath);
- fileio.mkdirSync(ddpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- file.list({
- uri: 'internal://cache/../files/File_List_002d',
- success: function (data) {
- console.info('File_List_002 call list success.' + JSON.stringify(data.fileList));
- fileio.unlinkSync(fpath);
- fileio.rmdirSync(ddpath);
- fileio.rmdirSync(dpath);
- done();
- },
- fail: function (data, code) {
- console.info('File_List_002 , code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_List_0300
- * @tc.name File_List_003
- * @tc.desc Function of API, check lastModifiedTime.The test file and dir are exist.
- */
- it('File_List_003', 0, async function (done) {
- let dpath = await fileName('File_List_003') + 'd';
- let fpath = dpath + '/File_List_003';
- let ddpath = dpath + '/File_List_003_1d';
- fileio.mkdirSync(dpath);
- fileio.mkdirSync(ddpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- file.list({
- uri: 'internal://cache/../files/File_List_003d',
- success: function (data) {
- console.info('File_List_003 call list success.' + JSON.stringify(data.fileList));
- done();
- },
- fail: function (data, code) {
- console.info('File_List_003 , code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- file.writeText({
- uri: 'internal://cache/../files/File_List_003d/File_List_003',
- text: '1',
- success: function (data) {
- console.info('File_List_003 call write success.');
- done();
- },
- fail: function (data, code) {
- console.info('File_List_003 , code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- file.list({
- uri: 'internal://cache/../files/File_List_003d',
- success: function (data) {
- console.info('File_List_003 call list success.' + JSON.stringify(data.fileList));
- fileio.unlinkSync(fpath);
- fileio.rmdirSync(ddpath);
- fileio.rmdirSync(dpath);
- done();
- },
- fail: function (data, code) {
- console.info('File_List_003 , code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_List_0400
- * @tc.name File_List_004
- * @tc.desc Function of API, check length.The test file and dir are exist.
- */
- it('File_List_004', 0, async function (done) {
- let dpath = await fileName('File_List_004') + 'd';
- let fpath = dpath + '/File_List_004';
- let ddpath = dpath + '/File_List_004_1d';
- fileio.mkdirSync(dpath);
- fileio.mkdirSync(ddpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- file.list({
- uri: 'internal://cache/../files/File_List_004d',
- success: function (data) {
- console.info('File_List_004 call list success.');
- done();
- },
- fail: function (data, code) {
- console.info('File_List_004 , code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_List_0500
- * @tc.name File_List_005
- * @tc.desc Function of API, check type.The test file and dir are exist.
- */
- it('File_List_005', 0, async function (done) {
- let dpath = await fileName('File_List_005') + 'd';
- let fpath = dpath + '/File_List_005';
- let ddpath = dpath + '/File_List_005_1d';
- fileio.mkdirSync(dpath);
- fileio.mkdirSync(ddpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- file.list({
- uri: 'internal://cache/../files/File_List_005d',
- success: function (data) {
- console.info('File_List_005 call list success.');
- done();
- },
- fail: function (data, code) {
- console.info('File_List_005 , code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_List_0600
- * @tc.name File_List_006
- * @tc.desc Function of API, error code:202
- */
- it('File_List_006', 0, async function (done) {
- let dpath = await fileName('File_List_006') + 'd'
- file.list({
- uri: dpath,
- success: function (data) {
- console.info('File_List_006 call list success.' + data.fileList);
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_List_006 , code: ' + code + ', data: ' + data);
- expect(code == 202).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_List_0700
- * @tc.name File_List_007
- * @tc.desc Function of API, uri set value of file.
- */
- it('File_List_007', 0, async function (done) {
- let fpath = await fileName('File_List_007');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- file.list({
- uri: 'internal://cache/../files/File_List_007',
- success: function (data) {
- console.info('File_List_007 pass, data.fileList:' + JSON.stringify(data.fileList));
- fileio.unlinkSync(fpath);
- done();
- },
- fail: function (data, code) {
- console.info('File_List_007 , code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_List_0800
- * @tc.name File_List_008
- * @tc.desc Function of API, error code: 301
- */
- it('File_List_008', 0, async function (done) {
- file.list({
- uri: 'internal://app/fakepath',
- success: function (data) {
- console.info('File_List_008 call list success.' + JSON.stringify(data.fileList));
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_List_008 , code: ' + code + ', data: ' + data);
- expect(code == 301).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_List_0900
- * @tc.name File_List_009
- * @tc.desc Function of API, uri too long.
- */
- it('File_List_009', 0, async function (done) {
- let firstPath = randomString(32);
- let dpath = await fileName(firstPath);
- let uri = 'internal://app/' + firstPath;
- fileio.mkdirSync(dpath);
- for (let i = 0; i < 16; i++) {
- console.info('time' + i);
- let sonPath = randomString(251);
- uri = uri + '/f' + sonPath;
- }
- file.list({
- uri: uri,
- success: function (data) {
- console.info('File_List_009 => pass' + data);
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_List_009 , code: ' + code + ', data: ' + data);
- expect(code == 300).assertTrue();
- fileio.rmdirSync(dpath);
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_List_1000
- * @tc.name File_List_010
- * @tc.desc Function of API, cache path.The test file and dir are exist.
- */
- it('File_List_010', 0, async function (done) {
- let dpath = await nextFileName('File_List_010d');
- let fpath = dpath + '/File_List_010';
- let ffpath = dpath + '/File_List_010_1';
- let ddpath = dpath + '/File_List_010_1d';
- let fffpath = ddpath + '/File_List_010_2';
- try {
- fileio.mkdirSync(dpath);
- fileio.mkdirSync(ddpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- expect(prepareFile(ffpath, FILE_CONTENT)).assertTrue();
- expect(prepareFile(fffpath, FILE_CONTENT)).assertTrue();
- }
- catch (e) {
- console.info('File_List_010 has failed for ' + e);
- expect(null).assertFail();
- }
- file.list({
- uri: 'internal://cache/File_List_010d',
- success: function (data) {
- console.info('File_List_010 => pass' + JSON.stringify(data.fileList));
- fileio.unlinkSync(fpath);
- fileio.unlinkSync(ffpath);
- fileio.unlinkSync(fffpath);
- fileio.rmdirSync(ddpath);
- fileio.rmdirSync(dpath);
- done();
- },
- fail: function (data, code) {
- console.info('File_List_010 fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_List_1100
- * @tc.name File_List_011
- * @tc.desc Function of API, virtual path.The test dir are exist.
- */
- it('File_List_011', 0, async function (done) {
- let dpath = await fileName('File_List_011') + 'd';
- let fpath = dpath + '/File_List_011';
- let ddpath = dpath + '/File_List_011_1d';
- fileio.mkdirSync(dpath);
- fileio.mkdirSync(ddpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- file.list({
- uri: 'internal://cache/../files/File_List_011d',
- success: function (data) {
- console.info('File_List_011 call list success.' + JSON.stringify(data.fileList));
- fileio.unlinkSync(fpath);
- fileio.rmdirSync(ddpath);
- fileio.rmdirSync(dpath);
- done();
- },
- fail: function (data, code) {
- console.info('File_List_011 fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_List_1200
- * @tc.name Function of API, out of package, Virtual path(create and give 777 authority).
- * @tc.desc The test dir are exist.
- */
- it('File_List_012', 0, async function (done) {
- file.list({
- uri: 'internal://cache/../files/../../',
- success: function (data) {
- console.info('File_List_012 call list success.' + JSON.stringify(data.fileList));
- done();
- },
- fail: function (data, code) {
- console.info('File_List_012 fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- complete: function () {
- console.info('list completed');
- }
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Get_0100
- * @tc.name File_Get_001
- * @tc.desc Function of API, Get.The test file is exist.
- */
- it('File_Get_001', 0, async function (done) {
- let fpath = await fileName('File_Get_001');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- file.get({
- uri: 'internal://cache/../files/File_Get_001',
- recursive: true,
- success: function (data) {
- console.info('File_Get_001 pass,data.uri:' );
- fileio.unlinkSync(fpath);
- done();
- },
- fail: function (data, code) {
- console.info('File_Get_001 fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Get_0200
- * @tc.name File_Get_002
- * @tc.desc Function of API, recursive = false.The test file is exist.
- */
- it('File_Get_002', 0, async function (done) {
- let fpath = await fileName('File_Get_002');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- file.get({
- uri: 'internal://cache/../files/File_Get_002',
- recursive: false,
- success: function (data) {
- console.info('File_Get_002 => file list:');
- console.info('{uri:' );
- console.info('length:' + data.length);
- console.info('lastModifiedTime:' + data.lastModifiedTime);
- console.info('type:' + data.type);
- console.info('subFiles:' + data.subFiles + '}');
- fileio.unlinkSync(fpath);
- done();
- },
- fail: function (data, code) {
- console.info('File_Get_002 fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Get_0300
- * @tc.name File_Get_003
- * @tc.desc Function of API, not input recursive.The test file is exist.
- */
- it('File_Get_003', 0, async function (done) {
- let fpath = await fileName('File_Get_003');
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- file.get({
- uri: 'internal://cache/../files/File_Get_003',
- success: function (data) {
- console.info('File_Get_003 => file list:');
- console.info('{uri:' );
- console.info('length:' + data.length);
- console.info('lastModifiedTime:' + data.lastModifiedTime);
- console.info('type:' + data.type);
- console.info('subFiles:' + data.subFiles + '}');
- console.info('File_Get_003 => pass');
- fileio.unlinkSync(fpath);
- done();
- },
- fail: function (data, code) {
- console.info('File_Get_003 fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Get_0400
- * @tc.name File_Get_004
- * @tc.desc Function of API, recursive = ture.The test file is exist.
- */
- it('File_Get_004', 0, async function (done) {
- let dpath = await fileName('File_Get_004d');
- let ddpath = dpath + '/File_Get_004dd'
- let fpath = dpath + '/File_Get_004f'
- let ffpath = ddpath + '/File_Get_004ff'
- fileio.mkdirSync(dpath);
- fileio.mkdirSync(ddpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- expect(prepareFile(ffpath, FILE_CONTENT)).assertTrue();
- file.get({
- uri: 'internal://cache/../files/File_Get_004d',
- recursive: true,
- success: function (data) {
- console.info('File_Get_004 => file list:');
- console.info('{uri:' );
- console.info('length:' + data.length);
- console.info('lastModifiedTime:' + data.lastModifiedTime);
- console.info('type:' + data.type);
- console.info('subFiles:' + data.subFiles + '}');
- console.info('File_Get_004 => pass');
- fileio.unlinkSync(ffpath);
- fileio.unlinkSync(fpath);
- fileio.rmdirSync(ddpath);
- fileio.rmdirSync(dpath);
- done();
- },
- fail: function (data, code) {
- console.info('File_Get_004 fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Get_0500
- * @tc.name File_Get_005
- * @tc.desc Function of API, recursive = false.The test file is exist.
- */
- it('File_Get_005', 0, async function (done) {
- let dpath = await fileName('File_Get_005d');
- let ddpath = dpath + '/File_Get_005dd';
- let fpath = dpath + '/File_Get_005f';
- let ffpath = ddpath + '/File_Get_005ff';
- fileio.mkdirSync(dpath);
- fileio.mkdirSync(ddpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- expect(prepareFile(ffpath, FILE_CONTENT)).assertTrue();
- file.get({
- uri: 'internal://cache/../files/File_Get_005d',
- recursive: false,
- success: function (data) {
- console.info('File_Get_005 => file list :');
- console.info('{uri:' );
- console.info('length:' + data.length);
- console.info('lastModifiedTime:' + data.lastModifiedTime);
- console.info('type:' + data.type);
- console.info('subFiles:' + data.subFiles + '}');
- console.info('File_Get_005 => pass');
- fileio.unlinkSync(ffpath);
- fileio.unlinkSync(fpath);
- fileio.rmdirSync(ddpath);
- fileio.rmdirSync(dpath);
- done();
- },
- fail: function (data, code) {
- console.info('File_Get_005 fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Get_0600
- * @tc.name File_Get_006
- * @tc.desc Function of API, not input recursive.The test file is exist.
- */
- it('File_Get_006', 0, async function (done) {
- let dpath = await fileName('File_Get_006d');
- let ddpath = dpath + '/File_Get_006dd';
- let fpath = dpath + '/File_Get_006f';
- let ffpath = ddpath + '/File_Get_006ff';
- fileio.mkdirSync(dpath);
- fileio.mkdirSync(ddpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- expect(prepareFile(ffpath, FILE_CONTENT)).assertTrue();
- file.get({
- uri: 'internal://cache/../files/File_Get_006d',
- success: function (data) {
- console.info('File_Get_006 file list:');
- console.info('{uri:' );
- console.info('length:' + data.length);
- console.info('lastModifiedTime:' + data.lastModifiedTime);
- console.info('type:' + data.type);
- console.info('subFiles:' + data.subFiles + '}');
- console.info('File_Get_006 => pass');
- fileio.unlinkSync(ffpath);
- fileio.unlinkSync(fpath);
- fileio.rmdirSync(ddpath);
- fileio.rmdirSync(dpath);
- done();
- },
- fail: function (data, code) {
- console.info('File_Get_006 fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Get_0700
- * @tc.name File_Get_007
- * @tc.desc Function of API, not input uri.The test file is exist.
- */
- it('File_Get_007', 0, async function (done) {
- file.get({
- recursive: true,
- success: function (data) {
- console.info('File_Get_007 call Copy success.');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_Get_007 fail, code: ' + code + ', data: ' + data);
- expect(code == 202).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Get_0800
- * @tc.name File_Get_008
- * @tc.desc Function of API, not input parameter.The test file is exist.
- */
- it('File_Get_008', 0, async function (done) {
- file.get({
- success: function (data) {
- console.info(data);
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_Get_008 fail, code: ' + code + ', data: ' + data);
- expect(code == 202).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Get_0900
- * @tc.name File_Get_009
- * @tc.desc Function of API, error parameter.The test file and dir are not exist.
- */
- it('File_Get_009', 0, async function (done) {
- file.get({
- uri: 'internal://app/File_Get_009',
- success: function (data) {
- console.info('File_Get_009 call Copy success.');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_Get_009 fail, code: ' + code + ', data: ' + data);
- expect(code == 301).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Get_1000
- * @tc.name File_Get_010
- * @tc.desc Function of API, uri = -1.
- */
- it('File_Get_010', 0, async function (done) {
- file.get({
- uri: -1,
- success: function (data) {
- console.info('File_Get_010 call Copy success.');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_Get_010 fail, code: ' + code + ', data: ' + data);
- expect(code == 202).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Get_1100
- * @tc.name File_Get_011
- * @tc.desc Function of API, cacahe path.
- */
- it('File_Get_011', 0, async function (done) {
- file.writeText({
- uri: 'internal://cache/File_Get_011',
- text: 'test',
- success: function () {
- console.info('File_Get_011 writeText success');
- file.get({
- uri: 'internal://cache/File_Get_011',
- recursive: true,
- success: function (data) {
- console.info('file list');
- console.info('uri:' );
- console.info('length:' + data.length);
- console.info('lastModifiedTime:' + data.lastModifiedTime);
- console.info('type:' + data.type);
- console.info('subFiles:' + data.subFiles);
- file.delete({
- uri: 'internal://cache/File_Get_011',
- success: function () {
- console.info('File_Get_011 delete success');
- done();
- },
- fail: function (data, code) {
- console.info('File_Get_011 delete fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_Get_011 get fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- },
- fail: function (data, code) {
- console.info('File_Get_011 writeText fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Get_1200
- * @tc.name File_Get_012
- * @tc.desc Function of API, uri too long.
- */
- it('File_Get_012', 0, async function (done) {
- let firstPath = randomString(32);
- let dpath = await fileName(firstPath);
- let uri = 'internal://cache/' + firstPath;
- fileio.mkdirSync(dpath);
- for (let i = 0; i < 16; i++) {
- console.info('time' + i);
- let sonPath = randomString(251);
- uri = uri + '/f' + sonPath;
- }
- file.get({
- uri: uri,
- recursive: true,
- success: function (data) {
- console.info('file list');
- console.info('uri:' );
- console.info('length:' + data.length);
- console.info('lastModifiedTime:' + data.lastModifiedTime);
- console.info('type:' + data.type);
- console.info('subFiles:' + data.subFiles);
- console.info('File_Get_012 => pass');
- expect(null).assertFail();
- },
- fail: function (data, code) {
- console.info('File_Get_012 fail, code: ' + code + ', data: ' + data);
- expect(code == 300).assertTrue();
- done();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Get_1300
- * @tc.name File_Get_013
- * @tc.desc Function of API, virtual path.
- */
- it('File_Get_013', 0, async function (done) {
- let dpath = await fileName('File_Get_013d');
- let ddpath = dpath + '/File_Get_013dd';
- let fpath = dpath + '/File_Get_013f';
- let ffpath = ddpath + '/File_Get_013ff';
- fileio.mkdirSync(dpath);
- fileio.mkdirSync(ddpath);
- expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
- expect(prepareFile(ffpath, FILE_CONTENT)).assertTrue();
- file.get({
- uri: 'internal://cache/../files/../files/File_Get_013d',
- recursive: true,
- success: function (data) {
- console.info('File_Get_013 => file list:');
- console.info('{uri:' );
- console.info('length:' + data.length);
- console.info('lastModifiedTime:' + data.lastModifiedTime);
- console.info('type:' + data.type);
- console.info('subFiles:' + data.subFiles + '}');
- console.info('File_Get_013 => pass');
- fileio.unlinkSync(ffpath);
- fileio.unlinkSync(fpath);
- fileio.rmdirSync(ddpath);
- fileio.rmdirSync(dpath);
- done();
- },
- fail: function (data, code) {
- console.info('File_Get_013 fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- });
- });
-
- /**
- * @tc.number SUB_STORAGE_File_Get_1400
- * @tc.name File_Get_014
- * @tc.desc Function of API, out of package, Virtual path, save the dir authority.
- */
- it('File_Get_014', 0, async function (done) {
- file.get({
- uri: 'internal://cache/../files/../../',
- success: function (data) {
- console.info('File_Get_014 => file list :');
- console.info('{uri:' );
- console.info('length:' + data.length);
- console.info('lastModifiedTime:' + data.lastModifiedTime);
- console.info('type:' + data.type);
- console.info('subFiles:' + data.subFiles + '}');
- console.info('File_Get_014 => pass');
- done();
- },
- fail: function (data, code) {
- console.info('File_Get_014 fail, code: ' + code + ', data: ' + data);
- expect(null).assertFail();
- },
- complete: function () {
- console.info('get completed');
- }
- });
- });
- /**
- * @tc.number SUB_STORAGE_Document_Choose_0100
- * @tc.name Document_Choose_001
- * @tc.desc Function of API, choose file.The test file is exist.
- */
- it('File_Document_Choose_001', 0, async function (done) {
- try {
- let types = [];
- let code = await document.choose(types);
- let str = 'Error';
- console.info("getFileUri===>" + code);
- expect(str).assertTrue();
- done();
- }
- catch (e) {
- console.info('File_Document_Choose_001 has failed for ' + e.message);
- expect(e.message == "error").assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_STORAGE_Document_Choose_0200
- * @tc.name Document_Choose_002
- * @tc.desc Function of API, choose file.The test file is exist.
- */
- it('File_Document_Choose_002', 0, async function (done) {
- try {
- let uri = "";
- let code = await document.choose(function(err,uri){
-
- });
- console.info("getFileUri===>" + code);
- expect(uri).assertTrue();
- done();
- }
- catch (e) {
- console.info('File_Document_Choose_002 has failed for ' + e.message);
- expect(e.message == "error").assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_STORAGE_Document_Choose_0300
- * @tc.name Document_Choose_003
- * @tc.desc Function of API, choose file.The test file is exist.
- */
- it('File_Document_Choose_003', 0, async function (done) {
- try {
- let types = [];
- let uri = "";
- let code = await document.choose(types,function(err,uri){
-
- });
- console.info("getFileUri===>" + code);
- expect().assertTrue();
- done();
- }
- catch (e) {
- console.info('File_Document_Choose_003 has failed for ' + e.message);
- expect(e.message == "error").assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_STORAGE_Document_Show_0100
- * @tc.name Document_Show_001
- * @tc.desc Function of API, show file.The test file is exist.
- */
- it('File_Document_Show_001', 0, async function (done) {
- try {
- let type = "";
- let uri = "";
- let code = await document.show(uri,type);
- console.info("getFileUri===>" + code);
- expect().assertTrue();
- done();
- }
- catch (e) {
- console.info('File_Document_Show_001 has failed for ' + e.message);
- expect(e.message == "error").assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_STORAGE_Document_Show_0200
- * @tc.name Document_Show_002
- * @tc.desc Function of API, show file.The test file is exist.
- */
- it('File_Document_Show_002', 0, async function (done) {
- try {
- let type = "";
- let uri ="";
- let code = await document.show(uri,type,function(err){
-
- });
- console.info("getFileUri===>" + code);
- expect().assertTrue();
- done();
- }
- catch (e) {
- console.info('File_Document_Show_002 has failed for ' + e.message);
- expect(e.message == "error").assertTrue();
- done();
- }
- });
-});
-}
+/*
+ * Copyright (C) 2021 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import fileio from '@ohos.fileio';
+import file from '@system.file';
+import document from '@ohos.document';
+import {
+ describe,
+ it,
+ expect
+}
+from '@ohos/hypium'
+import {
+ FILE_CONTENT,
+ prepareFile,
+ fileName,
+ randomString,
+ cacheFileName,
+ prepareEmptyFile,
+ nextFileName,
+ sleep
+}
+from './Common'
+
+export default function fileTest() {
+describe('fileTest', function () {
+
+ /**
+ * @tc.number SUB_STORAGE_File_Delete_0100
+ * @tc.name File_Delete_001
+ * @tc.desc Function of API, delete file.The test file is exist.
+ */
+ it('File_Delete_001', 0, async function (done) {
+ let fpath = await fileName('File_Delete_001');
+ expect(prepareFile(fpath, 'hello')).assertTrue();
+ file.delete({
+ uri: 'internal://cache/../files/File_Delete_001',
+ success: function () {
+ console.info('File_Delete_001 call delete success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Delete_001 call delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Delete_0200
+ * @tc.name File_Delete_002
+ * @tc.desc Function of API, delete dir.The dir is empty.
+ */
+ it('File_Delete_002', 0, async function (done) {
+ file.mkdir({
+ uri: 'internal://cache/File_Delete_002',
+ success: function () {
+ console.info('File_Delete_002 call mkdir success.');
+ file.delete({
+ uri: 'internal://cache/File_Delete_002',
+ success: function () {
+ console.info('File_Delete_002 call delete success.');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Delete_002 call delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_Delete_002 call mkdir fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Delete_0300
+ * @tc.name File_Delete_003
+ * @tc.desc Function of API, error code: 202 The test file or dir are exist.
+ */
+ it('File_Delete_003', 0, async function (done) {
+ file.delete({
+ uri: 'internal://ohos/workspace/text.txt',
+ success: function () {
+ console.info('File_Delete_003 call delete success.');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_Delete_003 call delete fail, code: ' + code + ', data: ' + data);
+ expect(code == 202).assertTrue();
+ done();
+ },
+ });
+
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Delete_0400
+ * @tc.name File_Delete_004
+ * @tc.desc Function of API, error code: 300 The dir is exist with files.
+ */
+ it('File_Delete_004', 0, async function (done) {
+ let dpath = await fileName('File_Delete_004');
+ let fpath = dpath + '/File_Delete_004';
+ fileio.mkdirSync(dpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ file.delete({
+ uri: 'internal://app/File_Delete_004',
+ success: function () {
+ console.info('File_Delete_004 call delete success.');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_Delete_004 call delete fail, code: ' + code + ', data: ' + data);
+ expect(code == 300).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Delete_0500
+ * @tc.name File_Delete_005
+ * @tc.desc Function of API, error code: 301 The file and dir are not exist.
+ */
+ it('File_Delete_005', 0, async function (done) {
+ file.delete({
+ uri: 'internal://app/File_Delete_005',
+ success: function () {
+ console.info('File_Delete_005 call delete success.');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_Delete_005 call delete fail, code: ' + code + ', data: ' + data);
+ expect(code == 301).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Delete_0600
+ * @tc.name File_Delete_006
+ * @tc.desc uri address length more than 4096 The test file is exist.
+ */
+ it('File_Delete_006', 0, async function (done) {
+ let firstPath = randomString(32);
+ let dpath = await fileName(firstPath);
+ let uri = 'internal://cache/' + firstPath;
+ fileio.mkdirSync(dpath);
+ for (let i = 0; i < 16; i++) {
+ console.info('frequency' + i);
+ let sonPath = randomString(251);
+ uri = uri + '/f' + sonPath;
+ }
+ file.delete({
+ uri: uri,
+ success: function () {
+ console.info('File_Delete_006 call delete success');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_Delete_006 call delete fail, code: ' + code + ', data: ' + data);
+ expect(code == 300).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Delete_0700
+ * @tc.name File_Delete_007
+ * @tc.desc Function of API, delete file from cache.The test file on cache.
+ */
+ it('File_Delete_007', 0, async function (done) {
+ file.writeText({
+ uri: 'internal://cache/File_Delete_007',
+ text: 'test',
+ success: function () {
+ console.info('File_Delete_007 call writeText success');
+ file.delete({
+ uri: 'internal://cache/File_Delete_007',
+ success: function () {
+ console.info('File_Delete_007 call delete success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Delete_007 call delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_Delete_007 call writeText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Delete_0800
+ * @tc.name File_Delete_008.
+ * @tc.desc Function of API, delete file from Virtual path.The test file is exist.
+ */
+ it('File_Delete_008', 0, async function (done) {
+ file.writeText({
+ uri: 'internal://cache/../cache/File_Delete_008',
+ text: 'Text that just for test.',
+ success: function () {
+ console.info('File_Delete_008 call writeText success');
+ file.delete({
+ uri: 'internal://cache/../cache/File_Delete_008',
+ success: function () {
+ console.info('File_Delete_008 call delete success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Delete_008 call delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ complete: function () {
+ console.info('delete completed');
+ }
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_Delete_008 call writeText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_writeText_0100
+ * @tc.name File_writeText_001
+ * @tc.desc Function of API, write to file(app path).The test file is not exist.
+ */
+ it('File_writeText_001', 0, async function (done) {
+ file.writeText({
+ uri: 'internal://cache/File_writeText_001',
+ text: 'sawyerwang.',
+ success: function () {
+ console.info('File_writeText_001 call writeText success');
+ file.readText({
+ uri: 'internal://cache/File_writeText_001',
+ success: function (data) {
+ console.info('File_writeText_001 call read success. Content: ' );
+ file.delete({
+ uri: 'internal://cache/File_writeText_001',
+ success: function () {
+ console.info('File_writeText_001 call delete success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_001 call delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_001 call read fail , code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_001 call writeText fail , code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_writeText_0200
+ * @tc.name File_writeText_002
+ * @tc.desc Function of API, write to file.The test file is exist, it can be edited.
+ */
+ it('File_writeText_002', 0, async function (done) {
+ file.writeText({
+ uri: 'internal://cache/File_writeText_002',
+ text: 'Text1.',
+ success: function () {
+ console.info('File_writeText_002 call writeText success.');
+ file.writeText({
+ uri: 'internal://cache/File_writeText_002',
+ text: 'Text2.',
+ append: true,
+ success: function () {
+ console.info('File_writeText_002 call writeText success.');
+ file.readText({
+ uri: 'internal://cache/File_writeText_002',
+ success: function (data) {
+ console.info('File_writeText_002 call read success. Content: ' );
+ file.delete({
+ uri: 'internal://cache/File_writeText_002',
+ success: function () {
+ console.info('File_writeText_002 call delete success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_002 call delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_002 call read fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_002 call writeText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_002 call writeText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_writeText_0300
+ * @tc.name File_writeText_003
+ * @tc.desc Different types of strings for text.
+ */
+ it('File_writeText_003', 0, async function (done) {
+ let txt = 'hello 你好 ????? こんにちは ?????.'
+ file.writeText({
+ uri: 'internal://cache/File_writeText_003',
+ text: txt,
+ success: function () {
+ console.info('File_writeText_003 call writeText success.');
+ file.readText({
+ uri: 'internal://cache/File_writeText_003',
+ success: function (data) {
+ console.info('File_writeText_003 call read success. Content: ' );
+ file.delete({
+ uri: 'internal://cache/File_writeText_003',
+ success: function () {
+ console.info('File_writeText_003 call delete success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_003 call delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_003 call read fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_003 call writeText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_writeText_0400
+ * @tc.name File_writeText_004
+ * @tc.desc Defferent encoding(UTF-8).
+ */
+ it('File_writeText_004', 0, async function (done) {
+ file.writeText({
+ uri: 'internal://cache/File_writeText_004',
+ text: 'hello',
+ encoding: 'UTF-8',
+ success: function () {
+ console.info('File_writeText_004 call writeText success.');
+ file.readText({
+ uri: 'internal://cache/File_writeText_004',
+ encoding: 'UTF-8',
+ success: function (data) {
+ console.info('File_writeText_004 call readText success. Content: ' );
+ file.delete({
+ uri: 'internal://cache/File_writeText_004',
+ success: function () {
+ console.info('File_writeText_004 delete success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_004 delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_004 call readText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_004 call writeText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_writeText_0500
+ * @tc.name File_writeText_005
+ * @tc.desc Function of API, append mode.The test file is exist and it can be edited.
+ */
+ it('File_writeText_005', 0, async function (done) {
+ file.writeText({
+ uri: 'internal://cache/File_writeText_005',
+ text: 'hello,world',
+ success: function () {
+ console.info('File_writeText_005 call writeText success.');
+ file.writeText({
+ uri: 'internal://cache/File_writeText_005',
+ text: 'hello',
+ append: true,
+ success: function () {
+ console.info('File_writeText_005 call writeText success.');
+ file.readText({
+ uri: 'internal://cache/File_writeText_005',
+ success: function (data) {
+ console.info('File_writeText_005 call read success ' );
+ file.delete({
+ uri: 'internal://cache/File_writeText_005',
+ success: function () {
+ console.info('File_writeText_005 call delete success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_005 call delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_005 call readText fail , code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_005 call writeText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_005 call writeText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_writeText_0600
+ * @tc.name File_writeText_006
+ * @tc.desc Function of API, non-append mode.The test file is exist and it can be edited.
+ */
+ it('File_writeText_006', 0, async function (done) {
+ file.writeText({
+ uri: 'internal://cache/File_writeText_006',
+ text: 'hello',
+ success: function () {
+ console.info('File_writeText_006 call writeText success.');
+ file.readText({
+ uri: 'internal://cache/File_writeText_006',
+ success: function (data) {
+ console.info('File_writeText_006 call read success ' );
+ file.delete({
+ uri: 'internal://cache/File_writeText_006',
+ success: function () {
+ console.info('File_writeText_006 delete success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_006 delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_006 call readText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_006 call writeText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_writeText_0700
+ * @tc.name File_writeText_007
+ * @tc.desc Function of API, error code: 202 The test file and dir are exist.
+ */
+ it('File_writeText_007', 0, async function (done) {
+ file.writeText({
+ uri: '/data/accounts/account_0/appdata',
+ text: 'hello',
+ success: function () {
+ console.info('File_writeText_007 call writeText success.');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_007, code: ' + code + ', data: ' + data);
+ expect(code == 202).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_writeText_0800
+ * @tc.name File_writeText_008
+ * @tc.desc Function of API, error code: 300 The uri path is dir path.
+ */
+ it('File_writeText_008', 0, async function (done) {
+ let dpath = await nextFileName('File_writeText_008d');
+ fileio.mkdirSync(dpath);
+ file.writeText({
+ uri: 'internal://cache/File_writeText_008d/',
+ text: 'hello',
+ success: function () {
+ console.info('File_writeText_008 call writeText success.');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_008 , code: ' + code + ', data: ' + data);
+ expect(code == 300).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_writeText_0900
+ * @tc.name File_writeText_009
+ * @tc.desc Function of API, error code: 300.The file path is not exist.
+ */
+ it('File_writeText_009', 0, async function (done) {
+ file.writeText({
+ uri: 'internal://app/File_writeText_009d/File_writeText_009',
+ text: 'test',
+ success: function () {
+ console.info('File_writeText_009 call writeText success.');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_009 , code: ' + code + ', data: ' + data);
+ expect(code == 300).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_writeText_1000
+ * @tc.name File_writeText_010
+ * @tc.desc Function of API, write to file(cache path).The test file is not exist.
+ */
+ it('File_writeText_010', 0, async function (done) {
+ file.writeText({
+ uri: 'internal://cache/File_writeText_010',
+ text: 'test',
+ success: function () {
+ console.info('File_writeText_010 mkdir success');
+ file.delete({
+ uri: 'internal://cache/File_writeText_010',
+ success: function () {
+ console.info('File_writeText_010 delete success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_010 delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_010 writeText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_writeText_1100
+ * @tc.name File_writeText_011
+ * @tc.desc Function of API, Virtual path.The test file is exist.
+ */
+ it('File_writeText_011', 0, async function (done) {
+ file.writeText({
+ uri: 'internal://cache/../cache/File_writeText_011',
+ text: 'sawyerwang',
+ success: function () {
+ console.info('File_writeText_011 writeText success ');
+ file.readText({
+ uri: 'internal://cache/../cache/File_writeText_011',
+ success: function (data) {
+ console.info('File_writeText_011 readText success ' );
+ file.delete({
+ uri: 'internal://cache/../cache/File_writeText_011',
+ success: function () {
+ console.info('File_writeText_011 delete success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_011 delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_011 readText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeText_011 writeText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_writeText_1300
+ * @tc.name File_writeText_013
+ * @tc.desc Function of API, write file out of package, Virtual path, save the dir authority.The test file is exist.
+ */
+ it('File_writeText_013', 0, async function (done) {
+ file.writeText({
+ uri: 'internal://app/notdir/File_writeText_013',
+ text: 'sawyerwang',
+ success: function () {
+ console.info('File_writeText_013 mkdir success');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ expect(code == 300).assertTrue();
+ console.info('File_writeText_013 , code: ' + code + ', data: ' + data);
+ done();
+ },
+ complete: function () {
+ console.info('writeText completed');
+ }
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_writeArrayBuffer_0100
+ * @tc.name File_writeArrayBuffer_001
+ * @tc.desc Write the buffer content to file.(cache path, append mode) The file path is not exist.
+ */
+ it('File_writeArrayBuffer_001', 0, async function (done) {
+ let buf = new Uint8Array([48, 49, 50, 51, 65, 66, 67, 68, 32, 33]);
+ file.writeArrayBuffer({
+ uri: 'internal://cache/File_writeArrayBuffer_001',
+ buffer: buf,
+ append: true,
+ success: function () {
+ console.info('File_writeArrayBuffer_001 call writeArrayBuffer success.');
+ file.readArrayBuffer({
+ uri: 'internal://cache/File_writeArrayBuffer_001',
+ success: function (data) {
+ console.info('File_writeArrayBuffer_001 call readArrayBuffer success.' );
+ file.delete({
+ uri: 'internal://cache/File_writeArrayBuffer_001',
+ success: function () {
+ console.info('File_writeArrayBuffer_001 delete success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_001 delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_001 readArrayBuffer fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_001 writeArrayBuffer fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_writeArrayBuffer_0200
+ * @tc.name File_writeArrayBuffer_002
+ * @tc.desc Write the buffer content to file.(cache path, non-append mode) The file path is not exist.
+ */
+ it('File_writeArrayBuffer_002', 0, async function (done) {
+ let buf = new Uint8Array([48, 49, 50, 51, 65, 66, 67, 68, 32, 33]);
+ file.writeArrayBuffer({
+ uri: 'internal://cache/File_writeArrayBuffer_002',
+ buffer: buf,
+ success: function () {
+ console.info('File_writeArrayBuffer_002 call writeArrayBuffer success.');
+ file.readArrayBuffer({
+ uri: 'internal://cache/File_writeArrayBuffer_002',
+ success: function (data) {
+ console.info('File_writeArrayBuffer_002 call readArrayBuffer success.' );
+ file.delete({
+ uri: 'internal://cache/File_writeArrayBuffer_002',
+ success: function () {
+ console.info('File_writeArrayBuffer_002 delete success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_002 delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_002 readArrayBuffer fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_002 writeArrayBuffer fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_writeArrayBuffer_0300
+ * @tc.name File_writeArrayBuffer_003
+ * @tc.desc Write the buffer content to file.(cache path, append mode) The file path is not exist.
+ */
+ it('File_writeArrayBuffer_003', 0, async function (done) {
+ let buf = new Uint8Array([48, 49, 50, 51, 65, 66, 67, 68, 32, 33, 48, 49, 50, 51, 65, 66, 67, 68, 32, 33]);
+ file.writeArrayBuffer({
+ uri: 'internal://cache/File_writeArrayBuffer_003',
+ buffer: buf,
+ success: function () {
+ console.info('File_writeArrayBuffer_003 call writeText success.');
+ file.writeArrayBuffer({
+ uri: 'internal://cache/File_writeArrayBuffer_003',
+ buffer: buf,
+ append: true,
+ success: function () {
+ console.info('File_writeArrayBuffer_003 call writeArrayBuffer success.');
+ file.readArrayBuffer({
+ uri: 'internal://cache/File_writeArrayBuffer_003',
+ success: function (data) {
+ console.info('File_writeArrayBuffer_003 readArrayBuffer success:' );
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_003 readArrayBuffer fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_003 writeArrayBuffer append fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_003 writeArrayBuffer fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_writeArrayBuffer_0400
+ * @tc.name File_writeArrayBuffer_004
+ * @tc.desc Write the buffer content to file.(cache path, non-append mode) The file path is exist.
+ */
+ it('File_writeArrayBuffer_004', 0, async function (done) {
+ let buf = new Uint8Array([48, 49, 50, 51, 65, 66, 67, 68, 32, 33]);
+ file.writeArrayBuffer({
+ uri: 'internal://cache/File_writeArrayBuffer_004',
+ buffer: buf,
+ append: false,
+ success: function () {
+ console.info('File_writeArrayBuffer_004 success call writeText success.');
+ file.writeArrayBuffer({
+ uri: 'internal://cache/File_writeArrayBuffer_004',
+ buffer: buf,
+ append: false,
+ success: function () {
+ console.info('File_writeArrayBuffer_004 call writeArrayBuffer success.');
+ file.readArrayBuffer({
+ uri: 'internal://cache/File_writeArrayBuffer_004',
+ success: function (data) {
+ console.info('File_writeArrayBuffer_004: readArrayBuffer success ' );
+ file.delete({
+ uri: 'internal://cache/File_writeArrayBuffer_004',
+ success: function () {
+ console.info('File_writeArrayBuffer_004 call delete success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_004 delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_004 readArrayBuffer fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_004 writeArrayBuffer fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_004 writeText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_writeArrayBuffer_0500
+ * @tc.name File_writeArrayBuffer_005
+ * @tc.desc Function of API, set value for position.The file path is exist.
+ */
+ it('File_writeArrayBuffer_005', 0, async function (done) {
+ let buf = new Uint8Array([48, 49, 50, 51, 65, 66, 67, 68, 32, 33, 44, 55, 66, 77]);
+ file.writeArrayBuffer({
+ uri: 'internal://cache/File_writeArrayBuffer_005',
+ buffer: buf,
+ success: function () {
+ console.info('File_writeArrayBuffer_005 call writeText success.');
+ file.writeArrayBuffer({
+ uri: 'internal://cache/File_writeArrayBuffer_005',
+ buffer: buf,
+ position: 10,
+ success: function () {
+ console.info('File_writeArrayBuffer_005 call writeArrayBuffer success.');
+ file.readArrayBuffer({
+ uri: 'internal://cache/File_writeArrayBuffer_005',
+ success: function (data) {
+ console.info('File_writeArrayBuffer_005 read success:' );
+ file.delete({
+ uri: 'internal://cache/File_writeArrayBuffer_005',
+ success: function () {
+ console.info('File_writeArrayBuffer_005 call delete success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_005 delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_005 read fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_005 writeArrayBuffer fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_005 writeText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_writeArrayBuffer_0600
+ * @tc.name File_writeArrayBuffer_006
+ * @tc.desc Function of API, not set value for position & append.The file path is exist.
+ */
+ it('File_writeArrayBuffer_006', 0, async function (done) {
+ let buf = new Uint8Array([48, 49, 50, 51, 65, 66, 67, 68, 32, 33]);
+ file.writeArrayBuffer({
+ uri: 'internal://cache/File_writeArrayBuffer_006',
+ buffer: buf,
+ success: function () {
+ console.info('File_writeArrayBuffer_006 call writeText success.');
+ file.writeArrayBuffer({
+ uri: 'internal://cache/File_writeArrayBuffer_006',
+ buffer: buf,
+ success: function () {
+ console.info('File_writeArrayBuffer_006 call writeArrayBuffer success.');
+ file.readArrayBuffer({
+ uri: 'internal://cache/File_writeArrayBuffer_006',
+ success: function () {
+ console.info('File_writeArrayBuffer_006 call readArrayBuffer pass');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_006 readArrayBuffer fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_006 writeArrayBuffer fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_006 writeText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_writeArrayBuffer_0700
+ * @tc.name File_writeArrayBuffer_007
+ * @tc.desc Function of API, error code: 202
+ */
+ it('File_writeArrayBuffer_007', 0, async function (done) {
+ let buf = new Uint8Array([48, 49, 50, 51, 65, 66, 67, 68, 32, 33]);
+ file.writeArrayBuffer({
+ uri: '',
+ buffer: buf,
+ success: function () {
+ console.info('File_writeArrayBuffer_007 call writeArrayBuffer success.');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_007 , code: ' + code + ', data: ' + data);
+ expect(code == 202).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_writeArrayBuffer_0800
+ * @tc.name File_writeArrayBuffer_008
+ * @tc.desc Function of API, error code: 300
+ */
+ it('File_writeArrayBuffer_008', 0, async function (done) {
+ let buf = new Uint8Array([48, 49, 50, 51, 65, 66, 67, 68, 32, 33]);
+ file.mkdir({
+ uri: 'internal://app/File_writeArrayBuffer_008',
+ success: function () {
+ console.info('call mkdir success.');
+ done();
+ },
+ fail: function (data, code) {
+ console.error('call fail callback fail, code: ' + code + ', data: ' + data);
+ },
+ });
+ file.writeArrayBuffer({
+ uri: 'internal://app/notdir/File_writeArrayBuffer_008',
+ buffer: buf,
+ success: function () {
+ console.info('File_writeArrayBuffer_008 call writeArrayBuffer success.');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_008 , code: ' + code + ', data: ' + data);
+ expect(code == 300).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_writeArrayBuffer_0900
+ * @tc.name File_writeArrayBuffer_009
+ * @tc.desc Function of API, error code: 300
+ */
+ it('File_writeArrayBuffer_009', 0, async function (done) {
+ let buf = new Uint8Array([1, 2, 3, 4, 5, 6, 7, 8]);
+ file.writeArrayBuffer({
+ uri: 'internal://cache/File_writeArrayBuffer_009',
+ buffer: buf,
+ success: function () {
+ console.info('File_writeArrayBuffer_009 call writeArrayBuffer success');
+ file.readArrayBuffer({
+ uri: 'internal://cache/File_writeArrayBuffer_009',
+ success: function (data) {
+ console.info('File_writeArrayBuffer_009 call readArrayBuffer pass');
+ file.delete({
+ uri: 'internal://cache/File_writeArrayBuffer_009',
+ success: function () {
+ console.info('File_writeArrayBuffer_009 call delete success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_009 delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_009 readArrayBuffer fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_009 writeArrayBuffer fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_writeArrayBuffer_1000
+ * @tc.name File_writeArrayBuffer_010
+ * @tc.desc Function of API, path = cache, virtual path The test file is exist.
+ */
+ it('File_writeArrayBuffer_010', 0, async function (done) {
+ let buf = new Uint8Array([48, 49, 50, 51, 65, 66, 67, 68, 32, 33]);
+ file.writeArrayBuffer({
+ uri: 'internal://cache/../cache/File_writeArrayBuffer_010',
+ buffer: buf,
+ append: true,
+ success: function () {
+ console.info('File_writeArrayBuffer_010 call writeArrayBuffer success.');
+ file.readArrayBuffer({
+ uri: 'internal://cache/../cache/File_writeArrayBuffer_010',
+ success: function (data) {
+ console.info('File_writeArrayBuffer_010 call readArrayBuffer pass');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_010 readArrayBuffer fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_010 writeArrayBuffer fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_writeArrayBuffer_1200
+ * @tc.name File_writeArrayBuffer_012
+ * @tc.desc Function of API, out of package, Virtual path, save the dir authority.The test file is exist.
+ */
+ it('File_writeArrayBuffer_012', 0, async function (done) {
+ let buf = new Uint8Array([48, 49, 50, 51, 65, 66, 67, 68, 32, 33]);
+ file.writeArrayBuffer({
+ uri: 'internal://app/notdir/File_writeArrayBuffer_012',
+ buffer: buf,
+ append: true,
+ success: function () {
+ console.info('File_writeArrayBuffer_012 => pass');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_writeArrayBuffer_012 , code: ' + code + ', data: ' + data);
+ expect(code == 300).assertTrue();
+ done();
+ },
+ complete: function () {
+ console.info('writeArrayBuffer completed');
+ }
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_readText_0100
+ * @tc.name File_readText_001
+ * @tc.desc Function of API, readText, app path.
+ */
+ it('File_readText_001', 0, async function (done) {
+ file.writeText({
+ uri: 'internal://cache/File_readText_001',
+ text: 'Text that just for test.',
+ success: function () {
+ console.info('File_readText_001 call writeText success.');
+ file.readText({
+ uri: 'internal://cache/File_readText_001',
+ success: function (data) {
+ console.info('File_readText_001 call readText success.');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_readText_001 readText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_readText_001 writeText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_readText_0200
+ * @tc.name File_readText_002
+ * @tc.desc Function of API, encoding = UTF-8.The test file is exist.
+ */
+ it('File_readText_002', 0, async function (done) {
+ file.writeText({
+ uri: 'internal://cache/File_readText_002',
+ text: 'Text that just for test.',
+ encoding: 'utf-8',
+ success: function () {
+ console.info('File_readText_002 call writeText success.');
+ file.readText({
+ uri: 'internal://cache/File_readText_002',
+ encoding: 'utf-8',
+ success: function (data) {
+ console.info('File_readText_002 call readText success.');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_readText_002 readText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_readText_002 writeText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_readText_0300
+ * @tc.name File_readText_003
+ * @tc.desc Function of API, error code: 202.The test file and dir is exist.
+ */
+ it('File_readText_003', 0, async function (done) {
+ file.readText({
+ uri: '',
+ success: function (data) {
+ console.info(data.text);
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_readText_003 , code: ' + code + ', data: ' + data);
+ expect(code == 202).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_readText_0400
+ * @tc.name File_readText_004
+ * @tc.desc Function of API, error code: 300.The test dir is exist.
+ */
+ it('File_readText_004', 0, async function (done) {
+ file.readText({
+ uri: 'internal://cache/',
+ success: function (data) {
+ console.info(data.text);
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_readText_004 , code: ' + code + ', data: ' + data);
+ expect(code == 300).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_readText_0500
+ * @tc.name File_readText_005
+ * @tc.desc Function of API, error code: 301.The test file and dir is exist.
+ */
+ it('File_readText_005', 0, async function (done) {
+ file.readText({
+ uri: 'internal://cache/workspace/text.txt',
+ success: function (data) {
+ console.info(data.text);
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_readText_005 , code: ' + code + ', data: ' + data);
+ expect(code == 301).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_readText_0600
+ * @tc.name File_readText_006
+ * @tc.desc Function of API, readText, cache path.
+ */
+ it('File_readText_006', 0, async function (done) {
+ file.writeText({
+ uri: 'internal://cache/File_readText_006',
+ text: 'test',
+ success: function () {
+ console.info('File_readText_006 call success');
+ file.readText({
+ uri: 'internal://cache/File_readText_006',
+ success: function (data) {
+ console.info('File_readText_006 call success' );
+ file.delete({
+ uri: 'internal://cache/File_readText_006',
+ success: function () {
+ console.info('File_readText_006 call success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_readText_006 delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_readText_006 readText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_readText_006 writeText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_readText_0700
+ * @tc.name File_readText_007
+ * @tc.desc Function of API, virtual path.The test file is exist.
+ */
+ it('File_readText_007', 0, async function (done) {
+ file.writeText({
+ uri: 'internal://cache/../files/../files/File_readText_007',
+ text: 'Text that just for test.',
+ success: function () {
+ console.info('File_readText_007 call writeText success.');
+ file.readText({
+ uri: 'internal://cache/../files/../files/File_readText_007',
+ success: function (data) {
+ console.info('File_readText_007 call readText success. data.text:' );
+ file.delete({
+ uri: 'internal://cache/../files/../files/File_readText_007',
+ success: function () {
+ console.info('File_readText_007 call delete success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_readText_007 delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_readText_007 readText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_readText_007 writeText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_readText_0800
+ * @tc.name File_readText_008
+ * @tc.desc Function of API, virtual path.Test whether the files returned are equal.
+ */
+ it("File_readText_008", 0, async function (done) {
+ let fpath = await nextFileName("File_readText_008");
+ let text = "0123456789abcdefg";
+ expect(prepareFile(fpath, text)).assertTrue();
+ sleep(10);
+ try {
+ file.readText({
+ uri: "internal://cache/File_readText_008",
+ success: function (data) {
+ console.info("call readText success: " + data.text);
+ expect(text == data.text).assertTrue();
+ fileio.unlinkSync(fpath);
+ done();
+ },
+ fail: function (data, code) {
+ console.error("call fail callback fail, code: " + code + ", data: " + data);
+ expect(null).assertFail();
+ },
+ complete: function () {
+ console.info('readText completed');
+ }
+ });
+ } catch (e) {
+ console.info("File_readText_008 has failed for " + e);
+ expect(null).assertFail();
+ }
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_read_array_buffer_0100
+ * @tc.name File_read_array_buffer_001
+ * @tc.desc Function of API, readArrayBuffer, cache path.position = 0, length = 10.
+ */
+ it('File_read_array_buffer_001', 0, async function (done) {
+ var buffer = new Uint8Array([48, 49, 50, 51, 65, 66, 67, 68, 32, 33]);
+ file.writeArrayBuffer({
+ uri: 'internal://cache/File_read_array_buffer_001',
+ buffer: buffer,
+ success: function () {
+ console.info('File_read_array_buffer_001 call writeArrayBuffer success.');
+ file.readArrayBuffer({
+ uri: 'internal://cache/File_read_array_buffer_001',
+ position: 0,
+ length: 10,
+ success: function (data) {
+ console.info('File_read_array_buffer_001 call readArrayBuffer pass');
+ file.delete({
+ uri: 'internal://cache/File_read_array_buffer_001',
+ success: function () {
+ console.info('File_read_array_buffer_001 call delete success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_read_array_buffer_001 delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_read_array_buffer_001 readArrayBuffer fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_read_array_buffer_001 writeArrayBuffer fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_read_array_buffer_0200
+ * @tc.name File_read_array_buffer_002
+ * @tc.desc Function of API, readArrayBuffer,
+ */
+ it('File_read_array_buffer_002', 0, async function (done) {
+ var buffer = new Uint8Array([48, 49, 50, 51, 65, 66, 67, 68, 32, 33]);
+ file.writeArrayBuffer({
+ uri: 'internal://cache/File_read_array_buffer_002',
+ buffer: buffer,
+ success: function () {
+ console.info('File_read_array_buffer_002 call writeArrayBuffer success.');
+ file.readArrayBuffer({
+ uri: 'internal://cache/File_read_array_buffer_002',
+ success: function (data) {
+ console.info('File_read_array_buffer_002 call readArrayBuffer pass');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_read_array_buffer_002 readArrayBuffer fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_read_array_buffer_002 writeArrayBuffer fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_read_array_buffer_0300
+ * @tc.name File_read_array_buffer_003
+ * @tc.desc Function of API, readArrayBuffer, wrong uri.
+ */
+ it('File_read_array_buffer_003', 0, async function (done) {
+ file.readArrayBuffer({
+ uri: '',
+ success: function (data) {
+ console.info('File_read_array_buffer_003 call readArrayBuffer success: ' );
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_read_array_buffer_003 , code: ' + code + ', data: ' + data);
+ expect(code == 202).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_read_array_buffer_0400
+ * @tc.name File_read_array_buffer_004
+ * @tc.desc Function of API, readArrayBuffer, wrong position.
+ */
+ it('File_read_array_buffer_004', 0, async function (done) {
+ let fpath = await fileName('File_read_array_buffer_004');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ file.readArrayBuffer({
+ uri: fpath,
+ position: 100,
+ success: function (data) {
+ console.info('File_read_array_buffer_004 call readArrayBuffer success: ' );
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_read_array_buffer_004 , code: ' + code + ', data: ' + data);
+ expect(code == 202).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_read_array_buffer_0500
+ * @tc.name File_read_array_buffer_005
+ * @tc.desc Function of API, readArrayBuffer, wrong length.
+ */
+ it('File_read_array_buffer_005', 0, async function (done) {
+ let fpath = await fileName('File_read_array_buffer_005');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ file.readArrayBuffer({
+ uri: fpath,
+ length: -1,
+ success: function (data) {
+ console.info('File_read_array_buffer_005 call readArrayBuffer success: ' );
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_read_array_buffer_005 , code: ' + code + ', data: ' + data);
+ expect(code == 202).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_read_array_buffer_0600
+ * @tc.name File_read_array_buffer_006
+ * @tc.desc Function of API, error code: 202 Set uri is dir path.
+ */
+ it('File_read_array_buffer_006', 0, async function (done) {
+ file.readArrayBuffer({
+ uri: 'internal://app',
+ success: function (data) {
+ console.info('File_read_array_buffer_006 call readArrayBuffer success: ' );
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_read_array_buffer_006 , code: ' + code + ', data: ' + data);
+ expect(code == 202).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_read_array_buffer_0700
+ * @tc.name File_read_array_buffer_007
+ * @tc.desc Function of API, error code: 301
+ */
+ it('File_read_array_buffer_007', 0, async function (done) {
+ file.readArrayBuffer({
+ uri: 'internal://cache/File_read_array_buffer_007',
+ success: function (data) {
+ console.info('File_read_array_buffer_007 call readArrayBuffer success: ' );
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_read_array_buffer_007 , code: ' + code + ', data: ' + data);
+ expect(code == 301).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_read_array_buffer_0800
+ * @tc.name File_read_array_buffer_008
+ * @tc.desc Function of API, cache path.The test file is exist.
+ */
+ it('File_read_array_buffer_008', 0, async function (done) {
+ let buf = new Uint8Array([1, 2, 3, 4, 5, 6, 7, 8]);
+ file.writeArrayBuffer({
+ uri: 'internal://cache/File_read_array_buffer_008',
+ buffer: buf,
+ success: function () {
+ console.info('File_read_array_buffer_008 call writeArrayBuffer success');
+ file.readArrayBuffer({
+ uri: 'internal://cache/File_read_array_buffer_008',
+ success: function (data) {
+ console.info('File_read_array_buffer_008 call readArrayBuffer success ' );
+ file.delete({
+ uri: 'internal://cache/File_read_array_buffer_008',
+ success: function () {
+ console.info('File_read_array_buffer_008 call delete success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_read_array_buffer_008 delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_read_array_buffer_008 readArrayBuffer fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_read_array_buffer_008 writeArrayBuffer fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_read_array_buffer_0900
+ * @tc.name File_read_array_buffer_009
+ * @tc.desc Function of API, virtual path.The test file is exist.
+ */
+ it('File_read_array_buffer_009', 0, async function (done) {
+ var buffer = new Uint8Array([48, 49, 50, 51, 65, 66, 67, 68, 32, 33]);
+ file.writeArrayBuffer({
+ uri: 'internal://cache/../cache/File_read_array_buffer_009',
+ buffer: buffer,
+ success: function () {
+ console.info('File_read_array_buffer_009 call writeArrayBuffer success.');
+ file.readArrayBuffer({
+ uri: 'internal://cache/../cache/File_read_array_buffer_009',
+ position: 0,
+ length: 10,
+ success: function (data) {
+ console.info('File_read_array_buffer_009 call readArrayBuffer success. data.buffer:' );
+ file.delete({
+ uri: 'internal://cache/../cache/File_read_array_buffer_009',
+ success: function () {
+ console.info('File_read_array_buffer_009 call delete success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_read_array_buffer_009 delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_read_array_buffer_009 readArrayBuffer fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ complete: function () {
+ console.info('readArrayBuffer completed');
+ }
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_read_array_buffer_009 writeArrayBuffer fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_access_0100
+ * @tc.name File_access_001
+ * @tc.desc Function of API, access, cache path.The test file is exist.
+ */
+ it('File_access_001', 0, async function (done) {
+ file.writeText({
+ uri: 'internal://cache/File_access_001',
+ text: 'Text that just for test.',
+ success: function () {
+ console.info('File_access_001 call writeText success.');
+ file.access({
+ uri: 'internal://cache/File_access_001',
+ success: function () {
+ console.info('File_access_001 call access success.');
+ file.delete({
+ uri: 'internal://cache/File_access_001',
+ success: function () {
+ console.info('File_access_001 call delete success.');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_access_001 delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_access_001 access fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_access_001 writeText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_access_0200
+ * @tc.name File_access_002
+ * @tc.desc Function of API, access, app path.The test file is exist.
+ */
+ it('File_access_002', 0, async function (done) {
+ file.mkdir({
+ uri: 'internal://cache/File_access_002',
+ success: function () {
+ console.info('File_access_002 call mkdir success.');
+ file.access({
+ uri: 'internal://cache/File_access_002',
+ success: function () {
+ console.info('File_access_002 call access success.');
+ file.rmdir({
+ uri: 'internal://cache/File_access_002',
+ success: function () {
+ console.info('File_access_002 call rmdir success.');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_access_002 rmdir fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_access_002 access fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_access_002 mkdir fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_access_0300
+ * @tc.name File_access_003
+ * @tc.desc Function of API, error code: 202 The test file and dir are exist.
+ */
+ it('File_access_003', 0, async function (done) {
+ let fpath = await fileName('File_access_003');
+ file.access({
+ uri: fpath,
+ success: function () {
+ console.info('File_access_003 call access success.');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_access_003 , code: ' + code + ', data: ' + data);
+ expect(code == 202).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_access_0400
+ * @tc.name File_access_004
+ * @tc.desc Function of API, error code: 301
+ */
+ it('File_access_004', 0, async function (done) {
+ file.access({
+ uri: 'internal://app/File_access_004.txt',
+ success: function () {
+ console.info('File_access_004 call access success.');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_access_004 , code: ' + code + ', data: ' + data);
+ expect(code == 301).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_access_0500
+ * @tc.name File_access_005
+ * @tc.desc Function of API, error code: 301
+ */
+ it('File_access_005', 0, async function (done) {
+ file.access({
+ uri: 'internal://app/File_access_005',
+ success: function () {
+ console.info('File_access_005 call access success.');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_access_005 , code: ' + code + ', data: ' + data);
+ expect(code == 301).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_access_0600
+ * @tc.name File_access_006
+ * @tc.desc Function of API, parameter more than 4096.The test file and dir are exist.
+ */
+ it('File_access_006', 0, async function (done) {
+ let firstPath = randomString(32);
+ let dpath = await fileName(firstPath);
+ let uri = 'internal://cache/' + firstPath;
+ fileio.mkdirSync(dpath);
+ for (let i = 0; i < 16; i++) {
+ console.info('time' + i);
+ let sonPath = randomString(251);
+ uri = uri + '/f' + sonPath;
+ }
+ file.access({
+ uri: uri,
+ success: function () {
+ console.info('File_access_006 => pass');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_access_006 , code: ' + code + ', data: ' + data);
+ expect(code == 300).assertTrue();
+ fileio.rmdirSync(dpath);
+ done();
+ },
+ });
+
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_access_0700
+ * @tc.name File_access_007
+ * @tc.desc Function of API, app path.The test file is exist.
+ */
+ it('File_access_007', 0, async function (done) {
+ file.writeText({
+ uri: 'internal://cache/File_access_007',
+ text: 'hello',
+ success: function () {
+ console.info('File_access_007 writeText success ');
+ file.access({
+ uri: 'internal://cache/File_access_007',
+ success: function () {
+ console.info('File_access_007 access success');
+ file.delete({
+ uri: 'internal://cache/File_access_007',
+ success: function () {
+ console.info('File_access_007 delete success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_access_007 delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_access_007 access fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_access_007 writeText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_access_0800
+ * @tc.name File_access_008
+ * @tc.desc Function of API, virtual path.The test file is exist.
+ */
+ it('File_access_008', 0, async function (done) {
+ file.writeText({
+ uri: 'internal://cache/../cache/File_access_008',
+ text: 'Text that just for test.',
+ success: function () {
+ console.info('File_access_008 writeText success.');
+ file.access({
+ uri: 'internal://cache/../cache/File_access_008',
+ success: function () {
+ console.info('File_access_008 call access success.');
+ file.delete({
+ uri: 'internal://cache/../cache/File_access_008',
+ success: function () {
+ console.info('File_access_008 call delete success.');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_access_008 delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ }
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_access_008 access fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ complete: function () {
+ console.info('access completed');
+ }
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_access_008 writeText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_mkdir_0100
+ * @tc.name File_mkdir_001
+ * @tc.desc Function of API, mkdir, app path.
+ */
+ it('File_mkdir_001', 0, async function (done) {
+ file.mkdir({
+ uri: 'internal://cache/File_mkdir_001',
+ success: function () {
+ console.info('File_mkdir_001 call mkdir success.');
+ file.rmdir({
+ uri: 'internal://cache/File_mkdir_001',
+ success: function () {
+ console.info('File_mkdir_001 call rmdir success.');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_mkdir_001 rmdir fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_mkdir_001 mkdir fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_mkdir_0200
+ * @tc.name File_mkdir_002
+ * @tc.desc Function of API, mkdir, recursive not set value.
+ */
+ it('File_mkdir_002', 0, async function (done) {
+ file.mkdir({
+ uri: 'internal://app/test/File_mkdir_002',
+ success: function () {
+ console.info('File_mkdir_002 call mkdir success.');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_mkdir_002 , code: ' + code + ', data: ' + data);
+ expect(code == 300).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_mkdir_0300
+ * @tc.name File_mkdir_003
+ * @tc.desc Function of API, mkdir, recursive.
+ */
+ it('File_mkdir_003', 0, async function (done) {
+ file.mkdir({
+ uri: 'internal://cache/test/File_mkdir_003d',
+ recursive: true,
+ success: function () {
+ console.info('File_mkdir_003 call mkdir success.');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_mkdir_003 , code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_mkdir_0400
+ * @tc.name File_mkdir_004
+ * @tc.desc Function of API, error code: 202
+ */
+ it('File_mkdir_004', 0, async function (done) {
+ file.mkdir({
+ uri: 'internal://files/test/File_mkdir_002d',
+ success: function () {
+ console.info('File_mkdir_004 call mkdir success.');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_mkdir_004, code: ' + code + ', data: ' + data);
+ expect(code == 202).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_mkdir_0500
+ * @tc.name File_mkdir_005
+ * @tc.desc Function of API, special characters.
+ */
+ it('File_mkdir_005', 0, async function (done) {
+ file.mkdir({
+ uri: 'internal://cache/!@/<>',
+ success: function () {
+ console.info('File_mkdir_005 mkdir success');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_mkdir_005 fail, code: ' + code + ', data: ' + data);
+ expect(code == 300).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_mkdir_0600
+ * @tc.name File_mkdir_006
+ * @tc.desc Function of API, parameter too long.
+ */
+ it('File_mkdir_006', 0, async function (done) {
+ let fileName = randomString(257);
+ file.mkdir({
+ uri: 'internal://cache/' + fileName,
+ success: function () {
+ console.info('File_mkdir_006 mkdir success');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_mkdir_006 =>fail ,code:' + code + ',data: ' + data);
+ expect(code == 300).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_mkdir_0700
+ * @tc.name File_mkdir_007
+ * @tc.desc Function of API, cache path.
+ */
+ it('File_mkdir_007', 0, async function (done) {
+ file.mkdir({
+ uri: 'internal://cache/File_mkdir_007d',
+ success: function () {
+ console.info('File_mkdir_007 mkdir success');
+ file.rmdir({
+ uri: 'internal://cache/File_mkdir_007d',
+ success: function () {
+ console.info('File_mkdir_007 delete success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_mkdir_007 delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_mkdir_007 mkdir fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_mkdir_0800
+ * @tc.name File_mkdir_008
+ * @tc.desc Function of API, virtual path.
+ */
+ it('File_mkdir_008', 0, async function (done) {
+ file.mkdir({
+ uri: 'internal://cache/../files/File_mkdir_008',
+ success: function () {
+ console.info('File_mkdir_008 call mkdir success.');
+ file.rmdir({
+ uri: 'internal://cache/../files/File_mkdir_008',
+ success: function () {
+ console.info('File_mkdir_008 call rmdir success.');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_mkdir_008 rmdir fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_mkdir_008 mkdir fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_mkdir_1000
+ * @tc.name File_mkdir_010
+ * @tc.desc Function of API, out of package, out of package, Virtual path, save the dir authority.
+ */
+ it('File_mkdir_010', 0, async function (done) {
+ file.mkdir({
+ uri: 'internal://app/notdir/File_mkdir_010',
+ success: function () {
+ console.info('File_mkdir_010 call mkdir success.');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_mkdir_010 call mkdir callback fail, code: ' + code + ', data: ' + data);
+ expect(code == 300).assertTrue();
+ done();
+ },
+ complete: function () {
+ console.info('mkdir completed');
+ }
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_rmdir_0100
+ * @tc.name File_rmdir_001
+ * @tc.desc Function of API, rmdir, app path.The test dir is exist, and it can be delete, the dir is empty.
+ */
+ it('File_rmdir_001', 0, async function (done) {
+ file.mkdir({
+ uri: 'internal://cache/File_rmdir_001',
+ success: function () {
+ console.info('File_rmdir_001 call mkdir success.');
+ file.rmdir({
+ uri: 'internal://cache/File_rmdir_001',
+ success: function () {
+ console.info('File_rmdir_001 call rmdir success.');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_rmdir_001 rmdir fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_rmdir_001 mkdir fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_rmdir_0200
+ * @tc.name File_rmdir_002
+ * @tc.desc Function of API, recursive not set value.The test dir is exist, and it not empty.
+ */
+ it('File_rmdir_002', 0, async function (done) {
+ file.mkdir({
+ uri: 'internal://app/test/File_rmdir_002',
+ recursive: true,
+ success: function () {
+ console.info('File_rmdir_002 mkdir success.');
+ file.rmdir({
+ uri: 'internal://app/test',
+ recursive: false,
+ success: function () {
+ console.info('File_rmdir_002 call rmdir success.');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_rmdir_002 fail, code: ' + code + ', data: ' + data);
+ expect(code == 301 || code == 300).assertTrue();
+ done();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_rmdir_002 fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_rmdir_0300
+ * @tc.name File_rmdir_003
+ * @tc.desc Function of API, recursive = ture.The test dir is exist, and it not empty.
+ */
+ it('File_rmdir_003', 0, async function (done) {
+ file.mkdir({
+ uri: 'internal://cache/test/File_rmdir_003/File_rmdir_003_1/File_rmdir_003_2',
+ recursive: true,
+ success: function () {
+ console.info('File_rmdir_003 mkdir success.');
+ file.mkdir({
+ uri: 'internal://cache/test/File_rmdir_003_1/File_rmdir_003_1/File_rmdir_003_2',
+ recursive: true,
+ success: function () {
+ console.info('File_rmdir_003 mkdir success.');
+ file.mkdir({
+ uri: 'internal://cache/test/File_rmdir_003_2/File_rmdir_003_1/File_rmdir_003_2',
+ recursive: true,
+ success: function () {
+ console.info('File_rmdir_003 mkdir success.');
+ file.rmdir({
+ uri: 'internal://cache/test',
+ recursive: true,
+ success: function () {
+ console.info('File_rmdir_003 call rmdir success.');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_rmdir_003 , code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_rmdir_003 fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_rmdir_003 fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_rmdir_003 fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_rmdir_0400
+ * @tc.name File_rmdir_004
+ * @tc.desc Function of API, error code: 202
+ */
+ it('File_rmdir_004', 0, async function (done) {
+ file.rmdir({
+ uri: '/data/accounts/account_0/appdata/ohos.acts.distributeddatamgr.distributedfile/cache/',
+ success: function () {
+ console.info('File_rmdir_004 call rmdir success.');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_rmdir_004 , code: ' + code + ', data: ' + data);
+ expect(code == 202).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_rmdir_0500
+ * @tc.name File_rmdir_005
+ * @tc.desc Function of API, error code: 301
+ */
+ it('File_rmdir_005', 0, async function (done) {
+ file.rmdir({
+ uri: 'internal://app/123',
+ success: function () {
+ console.info('File_rmdir_005 call rmdir success.');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_rmdir_005 rmdir fail, code: ' + code + ', data: ' + data);
+ expect(code == 301).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_rmdir_0600
+ * @tc.name File_rmdir_006
+ * @tc.desc Function of API, too long path.
+ */
+ it('File_rmdir_006', 0, async function (done) {
+ let firstPath = randomString(255);
+ let uri = 'internal://cache/' + firstPath;
+ file.mkdir({
+ uri: uri,
+ success: function () {
+ console.info('File_rmdir_006 mkdir success');
+ file.rmdir({
+ uri: uri,
+ success: function () {
+ console.info('File_rmdir_006 rmdir success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_rmdir_006 rmdir fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_rmdir_006 mkdir fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_rmdir_0700
+ * @tc.name File_rmdir_007
+ * @tc.desc Function of API, cache path.The test dir is exist, and it can be delete, it is empty.
+ */
+ it('File_rmdir_007', 0, async function (done) {
+ file.mkdir({
+ uri: 'internal://cache/File_rmdir_007d',
+ success: function () {
+ console.info('File_rmdir_007 mkdir success');
+ file.rmdir({
+ uri: 'internal://cache/File_rmdir_007d',
+ success: function () {
+ console.info('File_rmdir_007 rmdir success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_rmdir_007 rmdir fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_rmdir_007 mkdir fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_rmdir_0800
+ * @tc.name File_rmdir_008
+ * @tc.desc Function of API, virtual path.The test dir is exist.
+ */
+ it('File_rmdir_008', 0, async function (done) {
+ file.mkdir({
+ uri: 'internal://cache/../files/File_rmdir_008',
+ success: function () {
+ console.info('File_rmdir_008 call mkdir success.');
+ file.rmdir({
+ uri: 'internal://cache/../files/File_rmdir_008',
+ success: function () {
+ console.info('File_rmdir_008 call rmdir success.');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_rmdir_008 rmdir fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_rmdir_008 mkdir fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_rmdir_1000
+ * @tc.name File_rmdir_010
+ * @tc.desc Function of API, out of package, Virtual path, save the dir authority.The test dir is exist.
+ */
+ it('File_rmdir_010', 0, async function (done) {
+ file.rmdir({
+ uri: 'internal://app/../../com.ohos.systemui',
+ success: function () {
+ console.info('File_rmdir_010 call rmdir success.');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_rmdir_010 call rmdir callback fail, code: ' + code + ', data: ' + data);
+ expect(code == 301).assertTrue();
+ done();
+ },
+ complete: function () {
+ console.info('rmdir completed');
+ }
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Move_0100
+ * @tc.name File_Move_001
+ * @tc.desc Function of API, move.The test file is exist.
+ */
+ it('File_Move_001', 0, async function (done) {
+ file.writeText({
+ uri: 'internal://cache/File_Move_001',
+ text: 'Text that just for test.',
+ success: function () {
+ console.info('File_Move_001 call writeText success.');
+ file.move({
+ srcUri: 'internal://cache/File_Move_001',
+ dstUri: 'internal://cache/File_Move_001_1',
+ success: function (data) {
+ console.info('File_Move_001 call writeText success. data:' + data);
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Move_001 move fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.error('File_Move_001 call writeText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Move_0200
+ * @tc.name File_Move_002
+ * @tc.desc Function of API, document integrity.The test file is exist.
+ */
+ it('File_Move_002', 0, async function (done) {
+ let typeArray = new Array('.txt', '.ppt', '.flac', '.mp4', '.so', '.zip');
+ let dpath = await fileName('cache');
+ fileio.mkdirSync(dpath);
+ for (let i = 0; i < typeArray.length; i++) {
+ let srcFpath = await fileName('File_Move_002') + typeArray[i];
+ let dstFpath = await cacheFileName('File_Move_002') + typeArray[i];
+ expect(prepareEmptyFile(srcFpath)).assertTrue();
+ file.move({
+ srcUri: 'internal://cache/../files/File_Move_002' + typeArray[i],
+ dstUri: 'internal://cache/../files/cache/File_Move_002' + typeArray[i],
+ success: function (uri) {
+ console.info('File_Move_002 call move success. uri: ' + uri);
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Move_002 , code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ }
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Move_0300
+ * @tc.name File_Move_003
+ * @tc.desc Function of API, different size file.The test file is exist.
+ */
+ it('File_Move_003', 0, async function (done) {
+ let srcFpath = await fileName('File_Move_003');
+ expect(prepareFile(srcFpath, FILE_CONTENT)).assertTrue();
+ let dstFpath = await cacheFileName('File_Move_003');
+ let srcUri = 'internal://cache/../files/File_Move_003';
+ let dstUri = 'internal://app/cache/File_Move_003';
+ file.move({
+ srcUri: srcUri,
+ dstUri: dstUri,
+ success: function () {
+ console.info('File_Move_003 call move success.');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Move_003 , code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Move_0400
+ * @tc.name File_Move_004
+ * @tc.desc Function of API, error code: 202.The test file is exist.
+ */
+ it('File_Move_004', 0, async function (done) {
+ let srcFpath = await fileName('File_Move_004');
+ expect(prepareFile(srcFpath, FILE_CONTENT)).assertTrue();
+ file.move({
+ srcUri: 'internal://app/File_Move_004',
+ dstUri: null,
+ success: function () {
+ console.info('File_Move_004 call move success.');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_Move_004 , code: ' + code + ', data: ' + data);
+ expect(code == 202).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Move_0500
+ * @tc.name File_Move_005
+ * @tc.desc Function of API, error code: 300.The test file is exist.
+ */
+ it('File_Move_005', 0, async function (done) {
+ let srcDpath = await fileName('File_Move_005d');
+ fileio.mkdirSync(srcDpath);
+ file.move({
+ srcUri: 'internal://cache/../files/File_Move_005d',
+ dstUri: 'internal://app/cache/File_Move_005d',
+ success: function () {
+ console.info('File_Move_005 call move success.');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Move_005 , code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Move_0600
+ * @tc.name File_Move_006
+ * @tc.desc Function of API, error code: 301.The test file is not exist.
+ */
+ it('File_Move_006', 0, async function (done) {
+ let dstUri = await fileName('File_Move_006');
+ expect(prepareFile(dstUri, FILE_CONTENT)).assertTrue();
+ file.move({
+ srcUri: 'internal://app/File_Move',
+ dstUri: 'internal://app/File_Move_006',
+ success: function () {
+ console.info('File_Move_006 call move success.');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_Move_006 , code: ' + code + ', data: ' + data);
+ expect(code == 301).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Move_0700
+ * @tc.name File_Move_007
+ * @tc.desc Function of API, uri more too long.
+ */
+ it('File_Move_007', 0, async function (done) {
+ let firstPath = randomString(32);
+ let dpath = await fileName(firstPath);
+ let uri = 'internal://app/' + firstPath;
+ fileio.mkdirSync(dpath);
+ for (let i = 0; i < 16; i++) {
+ console.info('time' + i);
+ let sonPath = randomString(251);
+ uri = uri + '/f' + sonPath;
+ }
+ file.move({
+ srcUri: uri,
+ dstUri: 'internal://cache/File_Move_007',
+ success: function () {
+ console.info('File_Move_007 => move success');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_Move_007 => move fail');
+ expect(code == 300).assertTrue();
+ done();
+ },
+ });
+ fileio.rmdirSync(dpath);
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Move_0800
+ * @tc.name File_Move_008
+ * @tc.desc Function of API, cache path.The test file is exist.
+ */
+ it('File_Move_008', 0, async function (done) {
+ file.writeText({
+ uri: 'internal://cache/File_Move_008',
+ text: 'sss',
+ success: function () {
+ console.info('File_Move_008 writeText success ');
+ file.move({
+ srcUri: 'internal://cache/File_Move_008',
+ dstUri: 'internal://app/File_Move_008',
+ success: function (uri) {
+ console.info('File_Move_008 move pass, uri:' + uri);
+ file.delete({
+ uri: 'internal://app/File_Move_008',
+ success: function () {
+ console.info('File_Move_008 delete success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Move_008 delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_Move_008 move fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_Move_008 writeText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Move_0900
+ * @tc.name File_Move_009
+ * @tc.desc Function of API, same path.
+ */
+ it('File_Move_009', 0, async function (done) {
+ let srcFpath = await fileName('File_Move_009');
+ expect(prepareFile(srcFpath, FILE_CONTENT)).assertTrue();
+ file.move({
+ srcUri: 'internal://app/File_Move_009',
+ dstUri: 'internal://app/File_Move_009',
+ success: function (data) {
+ console.info('File_Move_009 => pass');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Move_009 call move fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Move_1000
+ * @tc.name File_Move_010
+ * @tc.desc Function of API, dstFpath has same file.
+ */
+ it('File_Move_010', 0, async function (done) {
+ let srcFpath = await fileName('File_Move_010');
+ let dstFpath = await cacheFileName('File_Move_010');
+ expect(prepareFile(srcFpath, 'aaa')).assertTrue();
+ expect(prepareFile(dstFpath, 'bbb')).assertTrue();
+ file.move({
+ srcUri: 'internal://app/File_Move_010',
+ dstUri: 'internal://app/cache/File_Move_010',
+ success: function (data) {
+ console.info('File_Move_010 => pass');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_Move_010 , code: ' + code + ', data: ' + data);
+ expect(code == 300).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Move_1100
+ * @tc.name File_Move_011
+ * @tc.desc Function of API, move app path file to cache path.
+ */
+ it('File_Move_011', 0, async function (done) {
+ let srcFpath = await fileName('File_Move_011');
+ expect(prepareFile(srcFpath, FILE_CONTENT)).assertTrue();
+ file.move({
+ srcUri: 'internal://cache/../files/File_Move_011',
+ dstUri: 'internal://cache/File_Move_011',
+ success: function (uri) {
+ console.info('File_Move_011 => pass, uri' + uri);
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Move_011 , code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Move_1200
+ * @tc.name File_Move_012
+ * @tc.desc Function of API, out of package, Virtual path(create and give 777 authority).
+ */
+ it('File_Move_012', 0, async function (done) {
+ let srcFpath = await fileName('File_Move_012');
+ expect(prepareFile(srcFpath, FILE_CONTENT)).assertTrue();
+ file.move({
+ srcUri: 'internal://app/../files/File_Move_012',
+ dstUri: 'internal://app/notdir/File_Move_012',
+ success: function (uri) {
+ console.info('File_Move_012 => pass, uri' + uri);
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_Move_012 , code: ' + code + ', data: ' + data);
+ expect(code == 300).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Move_1400
+ * @tc.name File_Move_014
+ * @tc.desc Function of API, check back value.
+ */
+ it('File_Move_014', 0, async function (done) {
+ let srcFpath = await fileName('File_Move_014');
+ let dstFpath = await cacheFileName('File_Move_014');
+ expect(prepareFile(srcFpath, 'test')).assertTrue();
+ let dstUri = 'internal://cache/File_Move_014';
+ file.move({
+ srcUri: 'internal://cache/../files/File_Move_014',
+ dstUri: dstUri,
+ success: function (uri) {
+ console.info('File_Move_014 move pass');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Move_014 => fail , code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ complete: function () {
+ console.info('move completed');
+ }
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Copy_0100
+ * @tc.name File_Copy_001
+ * @tc.desc Function of API, copy, app path.The test file is exist.
+ */
+ it('File_Copy_001', 0, async function (done) {
+ let srcFpath = await fileName('File_Copy_001');
+ let dstFpath = await cacheFileName('File_Copy_001');
+ expect(prepareFile(srcFpath, 'test.')).assertTrue();
+ file.copy({
+ srcUri: 'internal://cache/../files/File_Copy_001',
+ dstUri: 'internal://cache/../files/cache/File_Copy_001',
+ success: function () {
+ console.info('File_Copy_001 call copy success.');
+ file.readText({
+ uri: 'internal://cache/../files/cache/File_Copy_001',
+ success: function (data) {
+ console.info('File_Copy_001 read success:' );
+ fileio.unlinkSync(srcFpath);
+ fileio.unlinkSync(dstFpath);
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Copy_001 readText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_Copy_001 copy fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Copy_0200
+ * @tc.name File_Copy_002
+ * @tc.desc Function of API, document integrity.The test file is exist.
+ */
+ it('File_Copy_002', 0, async function (done) {
+ let typeArray = new Array('.txt', '.ppt', '.flac', '.mp4', '.so', '.zip');
+ for (let i = 0; i < typeArray.length; i++) {
+ let srcFpath = await fileName('File_Copy_002') + typeArray[i];
+ let dstFpath = await cacheFileName('File_Copy_002') + typeArray[i];
+ expect(prepareEmptyFile(srcFpath)).assertTrue();
+ file.copy({
+ srcUri: 'internal://cache/../files/File_Copy_002' + typeArray[i],
+ dstUri: 'internal://cache/../files/cache/File_Copy_002' + typeArray[i],
+ success: function () {
+ console.info('File_Copy_002 call copy success.');
+ file.delete('internal://cache/../files/File_Copy_002' + typeArray[i]);
+ file.delete('internal://cache/../files/cache/File_Copy_002' + typeArray[i]);
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Copy_002 , code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ }
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Copy_0300
+ * @tc.name File_Copy_003
+ * @tc.desc Function of API, different size of files. The test file is exist.
+ */
+ it('File_Copy_003', 0, async function (done) {
+ let srcFpath = await fileName('File_Copy_003');
+ expect(prepareFile(srcFpath, FILE_CONTENT)).assertTrue();
+ let dstFpath = await cacheFileName('File_Copy_003');
+ file.copy({
+ srcUri: 'internal://cache/../files/File_Copy_003',
+ dstUri: 'internal://cache/../files/cache/File_Copy_003',
+ success: function () {
+ console.info('File_Copy_003 call copy success.');
+ file.readText({
+ uri: 'internal://cache/../files/cache/File_Copy_003',
+ success: function (data) {
+ console.info('File_Copy_003 readText success, data.text:');
+ fileio.unlinkSync(srcFpath);
+ fileio.unlinkSync(dstFpath);
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Copy_003 readText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_Copy_003 copy fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Copy_0400
+ * @tc.name File_Copy_004
+ * @tc.desc Function of API, error code: 202 The test file is exist.
+ */
+ it('File_Copy_004', 0, async function (done) {
+ let srcFpath = await fileName('File_Copy_004');
+ expect(prepareFile(srcFpath, FILE_CONTENT)).assertTrue();
+ file.copy({
+ srcUri: 'internal://app/File_Copy_004',
+ dstUri: null,
+ success: function () {
+ console.info('File_Copy_004 call copy success.');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_Copy_004 , code: ' + code + ', data: ' + data);
+ expect(code == 202).assertTrue();
+ fileio.unlinkSync(srcFpath);
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Copy_0500
+ * @tc.name File_Copy_005
+ * @tc.desc Function of API, error code: 300
+ */
+
+ it('File_Copy_005', 0, async function (done) {
+ file.mkdir({
+ uri: 'internal://cache/File_Copy_005d',
+ success: function () {
+ console.info('File_Copy_005 call mkdir success.');
+ file.copy({
+ srcUri: 'internal://cache/File_Copy_005d',
+ dstUri: 'internal://cache/File_Copy_005d_1',
+ success: function () {
+ console.info('File_Copy_005 call copy success.');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Copy_005 , code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.error('File_Copy_005 call mkdir fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Copy_0600
+ * @tc.name File_Copy_006
+ * @tc.desc Function of API, error code: 301
+ */
+ it('File_Copy_006', 0, async function (done) {
+ file.copy({
+ srcUri: 'internal://app/fakepath',
+ dstUri: 'internal://app/fakepath1',
+ success: function () {
+ console.info('File_Copy_006 call copy success.');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_Copy_006 , code: ' + code + ', data: ' + data);
+ expect(code == 301).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Copy_0700
+ * @tc.name File_Copy_007
+ * @tc.desc Function of API, uri too long.
+ */
+ it('File_Copy_007', 0, async function (done) {
+ let firstPath = randomString(32);
+ let dpath = await fileName(firstPath);
+ let uri = 'internal://cache/' + firstPath;
+ fileio.mkdirSync(dpath);
+ for (let i = 0; i < 16; i++) {
+ console.info('time' + i);
+ let sonPath = randomString(251);
+ uri = uri + '/f' + sonPath;
+ }
+ file.copy({
+ srcUri: uri,
+ dstUri: uri,
+ success: function () {
+ console.info('File_Copy_007 => copy success');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_Copy_007 => fail, code: ' + code + ', data: ' + data);
+ fileio.rmdirSync(dpath);
+ expect(code == 300).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Copy_0800
+ * @tc.name File_Copy_008
+ * @tc.desc Function of API, cache path.
+ */
+ it('File_Copy_008', 0, async function (done) {
+ file.writeText({
+ uri: 'internal://cache/File_Copy_008',
+ text: 'test',
+ success: function () {
+ console.info('File_Copy_008 mkdir success');
+ file.copy({
+ srcUri: 'internal://cache/File_Copy_008',
+ dstUri: 'internal://cache/../files/File_Copy_008',
+ success: function () {
+ console.info('File_Copy_008 copy success');
+ file.delete({
+ uri: 'internal://cache/../files/File_Copy_008',
+ success: function () {
+ console.info('File_Copy_008 delete success ');
+ file.delete({
+ uri: 'internal://cache/File_Copy_008',
+ success: function () {
+ console.info('File_Copy_008 delete success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Copy_008 cache delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_Copy_008 files delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_Copy_008 copy fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_Copy_008 writeText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Copy_0900
+ * @tc.name File_Copy_009
+ * @tc.desc Function of API, same path.
+ */
+ it('File_Copy_009', 0, async function (done) {
+ let srcFpath = await fileName('File_Copy_009');
+ expect(prepareFile(srcFpath, FILE_CONTENT)).assertTrue();
+ file.copy({
+ srcUri: 'internal://app/File_Copy_009',
+ dstUri: 'internal://app/File_Copy_009',
+ success: function (data) {
+ console.info('File_Copy_009 => pass');
+ fileio.unlinkSync(srcFpath);
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Copy_009 , code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Copy_1000
+ * @tc.name File_Copy_010
+ * @tc.desc Function of API, dstFpath path has same file.
+ */
+ it('File_Copy_010', 0, async function (done) {
+ let srcFpath = await fileName('File_Copy_010');
+ let dstFpath = await cacheFileName('File_Copy_010');
+ expect(prepareFile(srcFpath, 'aaa')).assertTrue();
+ expect(prepareFile(dstFpath, 'bbb')).assertTrue();
+ file.copy({
+ srcUri: 'internal://app/File_Copy_010',
+ dstUri: 'internal://app/cache/File_Copy_010',
+ success: function (data) {
+ console.info('File_Copy_010 => pass');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_Copy_010 , code: ' + code + ', data: ' + data);
+ console.info("code::" + code);
+ expect(code == 300).assertTrue();
+ fileio.unlinkSync(srcFpath);
+ fileio.unlinkSync(dstFpath);
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Copy_1100
+ * @tc.name File_Copy_011
+ * @tc.desc Function of API, copy file to cache path.The test file is exist.
+ */
+ it('File_Copy_011', 0, async function (done) {
+ let srcFpath = await fileName('File_Copy_011');
+ expect(prepareFile(srcFpath, 'test.')).assertTrue();
+ file.copy({
+ srcUri: 'internal://cache/../files/File_Copy_011',
+ dstUri: 'internal://cache/File_Copy_011',
+ success: function () {
+ console.info('File_Copy_011 copy pass');
+ file.readText({
+ uri: 'internal://cache/File_Copy_011',
+ success: function (data) {
+ console.info('File_Copy_011 read success:' );
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Copy_011 readText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_Copy_011 copy fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Copy_1200
+ * @tc.name File_Copy_012
+ * @tc.desc Function of API, out of package, Virtual path(create and give 777 authority).The test file is exist.
+ */
+ it('File_Copy_012', 0, async function (done) {
+ let srcFpath = await fileName('File_Copy_012');
+ expect(prepareFile(srcFpath, 'test')).assertTrue();
+ file.copy({
+ srcUri: 'internal://app/../files/File_Copy_012',
+ dstUri: 'internal://app/notdir/File_Move_012',
+ success: function () {
+ console.info('File_Copy_012 copy pass');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_Copy_012 , code: ' + code + ', data: ' + data);
+ expect(code == 300).assertTrue();
+ fileio.unlinkSync(srcFpath);
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Copy_1400
+ * @tc.name File_Copy_014
+ * @tc.desc Function of API, check back value.The test file is exist.
+ */
+
+ it('File_Copy_014', 0, async function (done) {
+ let srcFpath = await fileName('File_Copy_014');
+ let dstFpath = await cacheFileName('File_Copy_014');
+ expect(prepareFile(srcFpath, 'test')).assertTrue();
+ let dstUri = 'internal://cache/File_Copy_014';
+ file.copy({
+ srcUri: 'internal://cache/../files/File_Copy_014',
+ dstUri: dstUri,
+ success: function (uri) {
+ console.info('File_Copy_014 copy pass');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Copy_014 => fail , code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ complete: function () {
+ console.info('copy completed');
+ }
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_List_0100
+ * @tc.name File_List_001
+ * @tc.desc Function of API, list.The test file and dir are exist.
+ */
+ it('File_List_001', 0, async function (done) {
+ let dpath = await fileName('File_List_001') + 'd';
+ let fpath = dpath + '/File_List_001';
+ let ddpath = dpath + '/File_List_001_1d';
+ fileio.mkdirSync(dpath);
+ fileio.mkdirSync(ddpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ file.list({
+ uri: 'internal://cache/../files/File_List_001d',
+ success: function (data) {
+ console.info('File_List_001 call list success.' + JSON.stringify(data.fileList));
+ fileio.unlinkSync(fpath);
+ fileio.rmdirSync(ddpath);
+ fileio.rmdirSync(dpath);
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_List_001 , code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_List_0200
+ * @tc.name File_List_002
+ * @tc.desc Function of API, set value of uri.The test file and dir are exist.
+ */
+ it('File_List_002', 0, async function (done) {
+ let dpath = await fileName('File_List_002') + 'd';
+ let fpath = dpath + '/File_List_002';
+ let ddpath = dpath + '/File_List_002_1d';
+ fileio.mkdirSync(dpath);
+ fileio.mkdirSync(ddpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ file.list({
+ uri: 'internal://cache/../files/File_List_002d',
+ success: function (data) {
+ console.info('File_List_002 call list success.' + JSON.stringify(data.fileList));
+ fileio.unlinkSync(fpath);
+ fileio.rmdirSync(ddpath);
+ fileio.rmdirSync(dpath);
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_List_002 , code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_List_0300
+ * @tc.name File_List_003
+ * @tc.desc Function of API, check lastModifiedTime.The test file and dir are exist.
+ */
+ it('File_List_003', 0, async function (done) {
+ let dpath = await fileName('File_List_003') + 'd';
+ let fpath = dpath + '/File_List_003';
+ let ddpath = dpath + '/File_List_003_1d';
+ fileio.mkdirSync(dpath);
+ fileio.mkdirSync(ddpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ file.list({
+ uri: 'internal://cache/../files/File_List_003d',
+ success: function (data) {
+ console.info('File_List_003 call list success.' + JSON.stringify(data.fileList));
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_List_003 , code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ file.writeText({
+ uri: 'internal://cache/../files/File_List_003d/File_List_003',
+ text: '1',
+ success: function (data) {
+ console.info('File_List_003 call write success.');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_List_003 , code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ file.list({
+ uri: 'internal://cache/../files/File_List_003d',
+ success: function (data) {
+ console.info('File_List_003 call list success.' + JSON.stringify(data.fileList));
+ fileio.unlinkSync(fpath);
+ fileio.rmdirSync(ddpath);
+ fileio.rmdirSync(dpath);
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_List_003 , code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_List_0400
+ * @tc.name File_List_004
+ * @tc.desc Function of API, check length.The test file and dir are exist.
+ */
+ it('File_List_004', 0, async function (done) {
+ let dpath = await fileName('File_List_004') + 'd';
+ let fpath = dpath + '/File_List_004';
+ let ddpath = dpath + '/File_List_004_1d';
+ fileio.mkdirSync(dpath);
+ fileio.mkdirSync(ddpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ file.list({
+ uri: 'internal://cache/../files/File_List_004d',
+ success: function (data) {
+ console.info('File_List_004 call list success.');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_List_004 , code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_List_0500
+ * @tc.name File_List_005
+ * @tc.desc Function of API, check type.The test file and dir are exist.
+ */
+ it('File_List_005', 0, async function (done) {
+ let dpath = await fileName('File_List_005') + 'd';
+ let fpath = dpath + '/File_List_005';
+ let ddpath = dpath + '/File_List_005_1d';
+ fileio.mkdirSync(dpath);
+ fileio.mkdirSync(ddpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ file.list({
+ uri: 'internal://cache/../files/File_List_005d',
+ success: function (data) {
+ console.info('File_List_005 call list success.');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_List_005 , code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_List_0600
+ * @tc.name File_List_006
+ * @tc.desc Function of API, error code:202
+ */
+ it('File_List_006', 0, async function (done) {
+ let dpath = await fileName('File_List_006') + 'd'
+ file.list({
+ uri: dpath,
+ success: function (data) {
+ console.info('File_List_006 call list success.' + data.fileList);
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_List_006 , code: ' + code + ', data: ' + data);
+ expect(code == 202).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_List_0700
+ * @tc.name File_List_007
+ * @tc.desc Function of API, uri set value of file.
+ */
+ it('File_List_007', 0, async function (done) {
+ let fpath = await fileName('File_List_007');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ file.list({
+ uri: 'internal://cache/../files/File_List_007',
+ success: function (data) {
+ console.info('File_List_007 pass, data.fileList:' + JSON.stringify(data.fileList));
+ fileio.unlinkSync(fpath);
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_List_007 , code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_List_0800
+ * @tc.name File_List_008
+ * @tc.desc Function of API, error code: 301
+ */
+ it('File_List_008', 0, async function (done) {
+ file.list({
+ uri: 'internal://app/fakepath',
+ success: function (data) {
+ console.info('File_List_008 call list success.' + JSON.stringify(data.fileList));
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_List_008 , code: ' + code + ', data: ' + data);
+ expect(code == 301).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_List_0900
+ * @tc.name File_List_009
+ * @tc.desc Function of API, uri too long.
+ */
+ it('File_List_009', 0, async function (done) {
+ let firstPath = randomString(32);
+ let dpath = await fileName(firstPath);
+ let uri = 'internal://app/' + firstPath;
+ fileio.mkdirSync(dpath);
+ for (let i = 0; i < 16; i++) {
+ console.info('time' + i);
+ let sonPath = randomString(251);
+ uri = uri + '/f' + sonPath;
+ }
+ file.list({
+ uri: uri,
+ success: function (data) {
+ console.info('File_List_009 => pass' + data);
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_List_009 , code: ' + code + ', data: ' + data);
+ expect(code == 300).assertTrue();
+ fileio.rmdirSync(dpath);
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_List_1000
+ * @tc.name File_List_010
+ * @tc.desc Function of API, cache path.The test file and dir are exist.
+ */
+ it('File_List_010', 0, async function (done) {
+ let dpath = await nextFileName('File_List_010d');
+ let fpath = dpath + '/File_List_010';
+ let ffpath = dpath + '/File_List_010_1';
+ let ddpath = dpath + '/File_List_010_1d';
+ let fffpath = ddpath + '/File_List_010_2';
+ try {
+ fileio.mkdirSync(dpath);
+ fileio.mkdirSync(ddpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ expect(prepareFile(ffpath, FILE_CONTENT)).assertTrue();
+ expect(prepareFile(fffpath, FILE_CONTENT)).assertTrue();
+ }
+ catch (e) {
+ console.info('File_List_010 has failed for ' + e);
+ expect(null).assertFail();
+ }
+ file.list({
+ uri: 'internal://cache/File_List_010d',
+ success: function (data) {
+ console.info('File_List_010 => pass' + JSON.stringify(data.fileList));
+ fileio.unlinkSync(fpath);
+ fileio.unlinkSync(ffpath);
+ fileio.unlinkSync(fffpath);
+ fileio.rmdirSync(ddpath);
+ fileio.rmdirSync(dpath);
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_List_010 fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_List_1100
+ * @tc.name File_List_011
+ * @tc.desc Function of API, virtual path.The test dir are exist.
+ */
+ it('File_List_011', 0, async function (done) {
+ let dpath = await fileName('File_List_011') + 'd';
+ let fpath = dpath + '/File_List_011';
+ let ddpath = dpath + '/File_List_011_1d';
+ fileio.mkdirSync(dpath);
+ fileio.mkdirSync(ddpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ file.list({
+ uri: 'internal://cache/../files/File_List_011d',
+ success: function (data) {
+ console.info('File_List_011 call list success.' + JSON.stringify(data.fileList));
+ fileio.unlinkSync(fpath);
+ fileio.rmdirSync(ddpath);
+ fileio.rmdirSync(dpath);
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_List_011 fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_List_1200
+ * @tc.name Function of API, out of package, Virtual path(create and give 777 authority).
+ * @tc.desc The test dir are exist.
+ */
+ it('File_List_012', 0, async function (done) {
+ file.list({
+ uri: 'internal://cache/../files/../../',
+ success: function (data) {
+ console.info('File_List_012 call list success.' + JSON.stringify(data.fileList));
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_List_012 fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ complete: function () {
+ console.info('list completed');
+ }
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Get_0100
+ * @tc.name File_Get_001
+ * @tc.desc Function of API, Get.The test file is exist.
+ */
+ it('File_Get_001', 0, async function (done) {
+ let fpath = await fileName('File_Get_001');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ file.get({
+ uri: 'internal://cache/../files/File_Get_001',
+ recursive: true,
+ success: function (data) {
+ console.info('File_Get_001 pass,data.uri:' );
+ fileio.unlinkSync(fpath);
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Get_001 fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Get_0200
+ * @tc.name File_Get_002
+ * @tc.desc Function of API, recursive = false.The test file is exist.
+ */
+ it('File_Get_002', 0, async function (done) {
+ let fpath = await fileName('File_Get_002');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ file.get({
+ uri: 'internal://cache/../files/File_Get_002',
+ recursive: false,
+ success: function (data) {
+ console.info('File_Get_002 => file list:');
+ console.info('{uri:' );
+ console.info('length:' + data.length);
+ console.info('lastModifiedTime:' + data.lastModifiedTime);
+ console.info('type:' + data.type);
+ console.info('subFiles:' + data.subFiles + '}');
+ fileio.unlinkSync(fpath);
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Get_002 fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Get_0300
+ * @tc.name File_Get_003
+ * @tc.desc Function of API, not input recursive.The test file is exist.
+ */
+ it('File_Get_003', 0, async function (done) {
+ let fpath = await fileName('File_Get_003');
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ file.get({
+ uri: 'internal://cache/../files/File_Get_003',
+ success: function (data) {
+ console.info('File_Get_003 => file list:');
+ console.info('{uri:' );
+ console.info('length:' + data.length);
+ console.info('lastModifiedTime:' + data.lastModifiedTime);
+ console.info('type:' + data.type);
+ console.info('subFiles:' + data.subFiles + '}');
+ console.info('File_Get_003 => pass');
+ fileio.unlinkSync(fpath);
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Get_003 fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Get_0400
+ * @tc.name File_Get_004
+ * @tc.desc Function of API, recursive = ture.The test file is exist.
+ */
+ it('File_Get_004', 0, async function (done) {
+ let dpath = await fileName('File_Get_004d');
+ let ddpath = dpath + '/File_Get_004dd'
+ let fpath = dpath + '/File_Get_004f'
+ let ffpath = ddpath + '/File_Get_004ff'
+ fileio.mkdirSync(dpath);
+ fileio.mkdirSync(ddpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ expect(prepareFile(ffpath, FILE_CONTENT)).assertTrue();
+ file.get({
+ uri: 'internal://cache/../files/File_Get_004d',
+ recursive: true,
+ success: function (data) {
+ console.info('File_Get_004 => file list:');
+ console.info('{uri:' );
+ console.info('length:' + data.length);
+ console.info('lastModifiedTime:' + data.lastModifiedTime);
+ console.info('type:' + data.type);
+ console.info('subFiles:' + data.subFiles + '}');
+ console.info('File_Get_004 => pass');
+ fileio.unlinkSync(ffpath);
+ fileio.unlinkSync(fpath);
+ fileio.rmdirSync(ddpath);
+ fileio.rmdirSync(dpath);
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Get_004 fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Get_0500
+ * @tc.name File_Get_005
+ * @tc.desc Function of API, recursive = false.The test file is exist.
+ */
+ it('File_Get_005', 0, async function (done) {
+ let dpath = await fileName('File_Get_005d');
+ let ddpath = dpath + '/File_Get_005dd';
+ let fpath = dpath + '/File_Get_005f';
+ let ffpath = ddpath + '/File_Get_005ff';
+ fileio.mkdirSync(dpath);
+ fileio.mkdirSync(ddpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ expect(prepareFile(ffpath, FILE_CONTENT)).assertTrue();
+ file.get({
+ uri: 'internal://cache/../files/File_Get_005d',
+ recursive: false,
+ success: function (data) {
+ console.info('File_Get_005 => file list :');
+ console.info('{uri:' );
+ console.info('length:' + data.length);
+ console.info('lastModifiedTime:' + data.lastModifiedTime);
+ console.info('type:' + data.type);
+ console.info('subFiles:' + data.subFiles + '}');
+ console.info('File_Get_005 => pass');
+ fileio.unlinkSync(ffpath);
+ fileio.unlinkSync(fpath);
+ fileio.rmdirSync(ddpath);
+ fileio.rmdirSync(dpath);
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Get_005 fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Get_0600
+ * @tc.name File_Get_006
+ * @tc.desc Function of API, not input recursive.The test file is exist.
+ */
+ it('File_Get_006', 0, async function (done) {
+ let dpath = await fileName('File_Get_006d');
+ let ddpath = dpath + '/File_Get_006dd';
+ let fpath = dpath + '/File_Get_006f';
+ let ffpath = ddpath + '/File_Get_006ff';
+ fileio.mkdirSync(dpath);
+ fileio.mkdirSync(ddpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ expect(prepareFile(ffpath, FILE_CONTENT)).assertTrue();
+ file.get({
+ uri: 'internal://cache/../files/File_Get_006d',
+ success: function (data) {
+ console.info('File_Get_006 file list:');
+ console.info('{uri:' );
+ console.info('length:' + data.length);
+ console.info('lastModifiedTime:' + data.lastModifiedTime);
+ console.info('type:' + data.type);
+ console.info('subFiles:' + data.subFiles + '}');
+ console.info('File_Get_006 => pass');
+ fileio.unlinkSync(ffpath);
+ fileio.unlinkSync(fpath);
+ fileio.rmdirSync(ddpath);
+ fileio.rmdirSync(dpath);
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Get_006 fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Get_0700
+ * @tc.name File_Get_007
+ * @tc.desc Function of API, not input uri.The test file is exist.
+ */
+ it('File_Get_007', 0, async function (done) {
+ file.get({
+ recursive: true,
+ success: function (data) {
+ console.info('File_Get_007 call Copy success.');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_Get_007 fail, code: ' + code + ', data: ' + data);
+ expect(code == 202).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Get_0800
+ * @tc.name File_Get_008
+ * @tc.desc Function of API, not input parameter.The test file is exist.
+ */
+ it('File_Get_008', 0, async function (done) {
+ file.get({
+ success: function (data) {
+ console.info(data);
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_Get_008 fail, code: ' + code + ', data: ' + data);
+ expect(code == 202).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Get_0900
+ * @tc.name File_Get_009
+ * @tc.desc Function of API, error parameter.The test file and dir are not exist.
+ */
+ it('File_Get_009', 0, async function (done) {
+ file.get({
+ uri: 'internal://app/File_Get_009',
+ success: function (data) {
+ console.info('File_Get_009 call Copy success.');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_Get_009 fail, code: ' + code + ', data: ' + data);
+ expect(code == 301).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Get_1000
+ * @tc.name File_Get_010
+ * @tc.desc Function of API, uri = -1.
+ */
+ it('File_Get_010', 0, async function (done) {
+ file.get({
+ uri: -1,
+ success: function (data) {
+ console.info('File_Get_010 call Copy success.');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_Get_010 fail, code: ' + code + ', data: ' + data);
+ expect(code == 202).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Get_1100
+ * @tc.name File_Get_011
+ * @tc.desc Function of API, cacahe path.
+ */
+ it('File_Get_011', 0, async function (done) {
+ file.writeText({
+ uri: 'internal://cache/File_Get_011',
+ text: 'test',
+ success: function () {
+ console.info('File_Get_011 writeText success');
+ file.get({
+ uri: 'internal://cache/File_Get_011',
+ recursive: true,
+ success: function (data) {
+ console.info('file list');
+ console.info('uri:' );
+ console.info('length:' + data.length);
+ console.info('lastModifiedTime:' + data.lastModifiedTime);
+ console.info('type:' + data.type);
+ console.info('subFiles:' + data.subFiles);
+ file.delete({
+ uri: 'internal://cache/File_Get_011',
+ success: function () {
+ console.info('File_Get_011 delete success');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Get_011 delete fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_Get_011 get fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ },
+ fail: function (data, code) {
+ console.info('File_Get_011 writeText fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Get_1200
+ * @tc.name File_Get_012
+ * @tc.desc Function of API, uri too long.
+ */
+ it('File_Get_012', 0, async function (done) {
+ let firstPath = randomString(32);
+ let dpath = await fileName(firstPath);
+ let uri = 'internal://cache/' + firstPath;
+ fileio.mkdirSync(dpath);
+ for (let i = 0; i < 16; i++) {
+ console.info('time' + i);
+ let sonPath = randomString(251);
+ uri = uri + '/f' + sonPath;
+ }
+ file.get({
+ uri: uri,
+ recursive: true,
+ success: function (data) {
+ console.info('file list');
+ console.info('uri:' );
+ console.info('length:' + data.length);
+ console.info('lastModifiedTime:' + data.lastModifiedTime);
+ console.info('type:' + data.type);
+ console.info('subFiles:' + data.subFiles);
+ console.info('File_Get_012 => pass');
+ expect(null).assertFail();
+ },
+ fail: function (data, code) {
+ console.info('File_Get_012 fail, code: ' + code + ', data: ' + data);
+ expect(code == 300).assertTrue();
+ done();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Get_1300
+ * @tc.name File_Get_013
+ * @tc.desc Function of API, virtual path.
+ */
+ it('File_Get_013', 0, async function (done) {
+ let dpath = await fileName('File_Get_013d');
+ let ddpath = dpath + '/File_Get_013dd';
+ let fpath = dpath + '/File_Get_013f';
+ let ffpath = ddpath + '/File_Get_013ff';
+ fileio.mkdirSync(dpath);
+ fileio.mkdirSync(ddpath);
+ expect(prepareFile(fpath, FILE_CONTENT)).assertTrue();
+ expect(prepareFile(ffpath, FILE_CONTENT)).assertTrue();
+ file.get({
+ uri: 'internal://cache/../files/../files/File_Get_013d',
+ recursive: true,
+ success: function (data) {
+ console.info('File_Get_013 => file list:');
+ console.info('{uri:' );
+ console.info('length:' + data.length);
+ console.info('lastModifiedTime:' + data.lastModifiedTime);
+ console.info('type:' + data.type);
+ console.info('subFiles:' + data.subFiles + '}');
+ console.info('File_Get_013 => pass');
+ fileio.unlinkSync(ffpath);
+ fileio.unlinkSync(fpath);
+ fileio.rmdirSync(ddpath);
+ fileio.rmdirSync(dpath);
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Get_013 fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ });
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_File_Get_1400
+ * @tc.name File_Get_014
+ * @tc.desc Function of API, out of package, Virtual path, save the dir authority.
+ */
+ it('File_Get_014', 0, async function (done) {
+ file.get({
+ uri: 'internal://cache/../files/../../',
+ success: function (data) {
+ console.info('File_Get_014 => file list :');
+ console.info('{uri:' );
+ console.info('length:' + data.length);
+ console.info('lastModifiedTime:' + data.lastModifiedTime);
+ console.info('type:' + data.type);
+ console.info('subFiles:' + data.subFiles + '}');
+ console.info('File_Get_014 => pass');
+ done();
+ },
+ fail: function (data, code) {
+ console.info('File_Get_014 fail, code: ' + code + ', data: ' + data);
+ expect(null).assertFail();
+ },
+ complete: function () {
+ console.info('get completed');
+ }
+ });
+ });
+ /**
+ * @tc.number SUB_STORAGE_Document_Choose_0100
+ * @tc.name Document_Choose_001
+ * @tc.desc Function of API, choose file.The test file is exist.
+ */
+ it('File_Document_Choose_001', 0, async function (done) {
+ try {
+ let types = [];
+ let code = await document.choose(types);
+ let str = 'Error';
+ console.info("getFileUri===>" + code);
+ expect(str).assertTrue();
+ done();
+ }
+ catch (e) {
+ console.info('File_Document_Choose_001 has failed for ' + e.message);
+ expect(e.message == "error").assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_Document_Choose_0200
+ * @tc.name Document_Choose_002
+ * @tc.desc Function of API, choose file.The test file is exist.
+ */
+ it('File_Document_Choose_002', 0, async function (done) {
+ try {
+ let uri = "";
+ let code = await document.choose(function(err,uri){
+
+ });
+ console.info("getFileUri===>" + code);
+ expect(uri).assertTrue();
+ done();
+ }
+ catch (e) {
+ console.info('File_Document_Choose_002 has failed for ' + e.message);
+ expect(e.message == "error").assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_Document_Choose_0300
+ * @tc.name Document_Choose_003
+ * @tc.desc Function of API, choose file.The test file is exist.
+ */
+ it('File_Document_Choose_003', 0, async function (done) {
+ try {
+ let types = [];
+ let uri = "";
+ let code = await document.choose(types,function(err,uri){
+
+ });
+ console.info("getFileUri===>" + code);
+ expect().assertTrue();
+ done();
+ }
+ catch (e) {
+ console.info('File_Document_Choose_003 has failed for ' + e.message);
+ expect(e.message == "error").assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_Document_Show_0100
+ * @tc.name Document_Show_001
+ * @tc.desc Function of API, show file.The test file is exist.
+ */
+ it('File_Document_Show_001', 0, async function (done) {
+ try {
+ let type = "";
+ let uri = "";
+ let code = await document.show(uri,type);
+ console.info("getFileUri===>" + code);
+ expect().assertTrue();
+ done();
+ }
+ catch (e) {
+ console.info('File_Document_Show_001 has failed for ' + e.message);
+ expect(e.message == "error").assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_STORAGE_Document_Show_0200
+ * @tc.name Document_Show_002
+ * @tc.desc Function of API, show file.The test file is exist.
+ */
+ it('File_Document_Show_002', 0, async function (done) {
+ try {
+ let type = "";
+ let uri ="";
+ let code = await document.show(uri,type,function(err){
+
+ });
+ console.info("getFileUri===>" + code);
+ expect().assertTrue();
+ done();
+ }
+ catch (e) {
+ console.info('File_Document_Show_002 has failed for ' + e.message);
+ expect(e.message == "error").assertTrue();
+ done();
+ }
+ });
+});
+}
diff --git a/storage/storagefilejstest/entry/src/ohosTest/js/test/List.test.js b/storage/storagefilejstest/src/main/js/test/List.test.js
similarity index 90%
rename from storage/storagefilejstest/entry/src/ohosTest/js/test/List.test.js
rename to storage/storagefilejstest/src/main/js/test/List.test.js
index 89f142cf0c3d4dce0e993a11a4f9350b7ac558e9..310b09786bf19ae54b383d380b7238beda6041ba 100644
--- a/storage/storagefilejstest/entry/src/ohosTest/js/test/List.test.js
+++ b/storage/storagefilejstest/src/main/js/test/List.test.js
@@ -1,19 +1,19 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import fileTest from './File.test.js'
-export default function testsuite() {
- fileTest()
-}
+/*
+ * Copyright (C) 2021 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import fileTest from './File.test.js'
+export default function testsuite() {
+ fileTest()
+}
diff --git a/storage/storagefilejstest/entry/src/main/resources/base/element/string.json b/storage/storagefilejstest/src/main/resources/base/element/string.json
similarity index 94%
rename from storage/storagefilejstest/entry/src/main/resources/base/element/string.json
rename to storage/storagefilejstest/src/main/resources/base/element/string.json
index 1357196cbc6930c538004615c72b82b07441afe4..9d3fa1bb64c9d599c1fe17b05e95900b0eea025c 100644
--- a/storage/storagefilejstest/entry/src/main/resources/base/element/string.json
+++ b/storage/storagefilejstest/src/main/resources/base/element/string.json
@@ -1,28 +1,28 @@
-{
- "string": [
- {
- "name": "app_name",
- "value": "storagefilejstest"
- },
- {
- "name": "mainability_description",
- "value": "JS_Phone_Empty Feature Ability"
- },
- {
- "name": "MainAbility_desc",
- "value": "description"
- },
- {
- "name": "MainAbility_label",
- "value": "label"
- },
- {
- "name": "TestAbility_desc",
- "value": "description"
- },
- {
- "name": "TestAbility_label",
- "value": "label"
- }
- ]
-}
+{
+ "string": [
+ {
+ "name": "app_name",
+ "value": "storagefilejstest"
+ },
+ {
+ "name": "mainability_description",
+ "value": "JS_Phone_Empty Feature Ability"
+ },
+ {
+ "name": "MainAbility_desc",
+ "value": "description"
+ },
+ {
+ "name": "MainAbility_label",
+ "value": "label"
+ },
+ {
+ "name": "TestAbility_desc",
+ "value": "description"
+ },
+ {
+ "name": "TestAbility_label",
+ "value": "label"
+ }
+ ]
+}
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/resources/base/media/icon.png b/storage/storagefilejstest/src/main/resources/base/media/icon.png
similarity index 100%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/resources/base/media/icon.png
rename to storage/storagefilejstest/src/main/resources/base/media/icon.png
diff --git a/storage/storagefileurijstest/BUILD.gn b/storage/storagefileurijstest/BUILD.gn
index 5e98110b4ee114ea9571482ead37e2a37927334e..3f2dec2bc7a9de5604cafb021003a28308f3c2a4 100644
--- a/storage/storagefileurijstest/BUILD.gn
+++ b/storage/storagefileurijstest/BUILD.gn
@@ -1,4 +1,4 @@
-# Copyright (c) 2023 Huawei Device Co., Ltd.
+# Copyright (C) 2022 Huawei Device Co., Ltd.
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
@@ -13,11 +13,23 @@
import("//test/xts/tools/build/suite.gni")
-ohos_js_app_suite("storagefileuri_js_test") {
- test_hap = true
- testonly = true
+ohos_js_hap_suite("storagefileuri_js_test") {
+ hap_profile = "./src/main/config.json"
+ deps = [
+ ":storagefileuri_js_assets",
+ ":storagefileuri_js_resources",
+ ]
+ certificate_profile = "./signature/openharmony_sx.p7b"
hap_name = "ActsStorageFileUriJsTest"
subsystem_name = "filemanagement"
part_name = "app_file_service"
- certificate_profile = "./signature/openharmony_sx.p7b"
+}
+ohos_js_assets("storagefileuri_js_assets") {
+ js2abc = true
+ hap_profile = "./src/main/config.json"
+ source_dir = "./src/main/js"
+}
+ohos_resources("storagefileuri_js_resources") {
+ sources = [ "./src/main/resources" ]
+ hap_profile = "./src/main/config.json"
}
diff --git a/storage/storagefileurijstest/Test.json b/storage/storagefileurijstest/Test.json
index 3410879aba977230fd045f40d8ba410cf1e59a77..4b4be45f81adf94f5e73a7afd9a295d0af7c9e3b 100644
--- a/storage/storagefileurijstest/Test.json
+++ b/storage/storagefileurijstest/Test.json
@@ -5,7 +5,7 @@
"test-timeout": "60000",
"shell-timeout": "60000",
"bundle-name": "ohos.acts.storage.fileuri",
- "package-name": "ohos.acts.storage.fileuri_test"
+ "package-name": "ohos.acts.storage.fileuri"
},
"kits": [
{
diff --git a/storage/storagefileurijstest/build-profile.json5 b/storage/storagefileurijstest/build-profile.json5
deleted file mode 100644
index 7715cddc0112e0e0c8e40623b77ff67b82731829..0000000000000000000000000000000000000000
--- a/storage/storagefileurijstest/build-profile.json5
+++ /dev/null
@@ -1,42 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-{
- "app": {
- "signingConfigs": [
- ],
- "compileSdkVersion": 10,
- "compatibleSdkVersion": 10,
- "products": [
- {
- "name": "default",
- "signingConfig": "default"
- }
- ]
- },
- "modules": [
- {
- "name": "entry",
- "srcPath": "./entry",
- "targets": [
- {
- "name": "default",
- "applyToProducts": [
- "default"
- ]
- }
- ]
- }
- ]
-}
\ No newline at end of file
diff --git a/storage/storagefileurijstest/entry/build-profile.json5 b/storage/storagefileurijstest/entry/build-profile.json5
deleted file mode 100644
index a6a17e6971173aacea7b75d9ae897a80d335dc0b..0000000000000000000000000000000000000000
--- a/storage/storagefileurijstest/entry/build-profile.json5
+++ /dev/null
@@ -1,27 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-{
- "apiType": 'faMode',
- "buildOption": {
- },
- "targets": [
- {
- "name": "default",
- },
- {
- "name": "ohosTest",
- }
- ]
-}
\ No newline at end of file
diff --git a/storage/storagefileurijstest/entry/hvigorfile.ts b/storage/storagefileurijstest/entry/hvigorfile.ts
deleted file mode 100644
index 89d831db3f5a6431ef4f9078128ad61b6ae36c48..0000000000000000000000000000000000000000
--- a/storage/storagefileurijstest/entry/hvigorfile.ts
+++ /dev/null
@@ -1,16 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-// Script for compiling build behavior. It is built in the build plug-in and cannot be modified currently.
-export { legacyHapTasks } from '@ohos/hvigor-ohos-plugin';
diff --git a/storage/storagefileurijstest/entry/oh-package.json5 b/storage/storagefileurijstest/entry/oh-package.json5
deleted file mode 100644
index 75ca1d70feb1c490379299fe342058a2a7183388..0000000000000000000000000000000000000000
--- a/storage/storagefileurijstest/entry/oh-package.json5
+++ /dev/null
@@ -1,24 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-{
- "license": "",
- "devDependencies": {},
- "author": "",
- "name": "entry",
- "description": "Please describe the basic information.",
- "main": "",
- "version": "1.0.0",
- "dependencies": {}
-}
diff --git a/storage/storagefileurijstest/entry/src/main/config.json b/storage/storagefileurijstest/entry/src/main/config.json
deleted file mode 100644
index 5ccba530cb2e5bf2dd6d0e9f6d17271e31304a9b..0000000000000000000000000000000000000000
--- a/storage/storagefileurijstest/entry/src/main/config.json
+++ /dev/null
@@ -1,65 +0,0 @@
-{
- "app":{
- "bundleName":"ohos.acts.storage.fileuri",
- "vendor":"example",
- "version":{
- "code":1000000,
- "name":"1.0.0"
- }
- },
- "deviceConfig":{
-
- },
- "module":{
- "package":"ohos.acts.storage.fileuri",
- "name":".entry",
- "mainAbility":".MainAbility",
- "deviceType": [
- "tablet",
- "default"
- ],
- "distro":{
- "deliveryWithInstall":true,
- "installationFree":true,
- "moduleName":"entry",
- "moduleType":"entry"
- },
- "abilities":[
- {
- "description":"$string:MainAbility_desc",
- "formsEnabled":false,
- "icon":"$media:icon",
- "label":"$string:MainAbility_label",
- "launchType":"standard",
- "name":".MainAbility",
- "orientation":"unspecified",
- "skills":[
- {
- "actions":[
- "action.system.home"
- ],
- "entities":[
- "entity.system.home"
- ]
- }
- ],
- "srcLanguage":"js",
- "srcPath":"MainAbility",
- "type":"page",
- "visible":true
- }
- ],
- "js":[
- {
- "name":".MainAbility",
- "pages":[
- "pages/index/index"
- ],
- "window":{
- "autoDesignWidth":false,
- "designWidth":720
- }
- }
- ]
- }
-}
\ No newline at end of file
diff --git a/storage/storagefileurijstest/entry/src/main/js/MainAbility/app.js b/storage/storagefileurijstest/entry/src/main/js/MainAbility/app.js
deleted file mode 100644
index 8c9a4fce93b5e76779bdf446c49269a5a51db98a..0000000000000000000000000000000000000000
--- a/storage/storagefileurijstest/entry/src/main/js/MainAbility/app.js
+++ /dev/null
@@ -1,26 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-import hilog from '@ohos.hilog';
-export default {
- onCreate() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'Application onCreate');
- },
- onDestroy() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'Application onDestroy');
- },
-}
-
-
-
diff --git a/storage/storagefileurijstest/entry/src/main/js/MainAbility/pages/index/index.css b/storage/storagefileurijstest/entry/src/main/js/MainAbility/pages/index/index.css
deleted file mode 100644
index a711febae0b34889547cd72fbe5f8cc3e0bd043c..0000000000000000000000000000000000000000
--- a/storage/storagefileurijstest/entry/src/main/js/MainAbility/pages/index/index.css
+++ /dev/null
@@ -1,60 +0,0 @@
-/*
- * Copyright (c) 2022 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-.container {
- flex-direction: column;
- justify-content: center;
- align-items: center;
- width: 100%;
- height: 100%;
-}
-
-.title {
- font-size: 40px;
- color: #000000;
- opacity: 0.9;
-}
-
-@media screen and (device-type: tablet) and (orientation: landscape) {
- .title {
- font-size: 100px;
- }
-}
-
-@media screen and (device-type: wearable) {
- .title {
- font-size: 28px;
- color: #FFFFFF;
- }
-}
-
-@media screen and (device-type: tv) {
- .container {
- background-image: url("/common/images/Wallpaper.png");
- background-size: cover;
- background-repeat: no-repeat;
- background-position: center;
- }
-
- .title {
- font-size: 100px;
- color: #FFFFFF;
- }
-}
-
-@media screen and (device-type: phone) and (orientation: landscape) {
- .title {
- font-size: 60px;
- }
-}
diff --git a/storage/storagefileurijstest/entry/src/main/js/MainAbility/pages/index/index.hml b/storage/storagefileurijstest/entry/src/main/js/MainAbility/pages/index/index.hml
deleted file mode 100644
index 95bd1e877b3fa9f5f4e4dc0ff608591b540d116d..0000000000000000000000000000000000000000
--- a/storage/storagefileurijstest/entry/src/main/js/MainAbility/pages/index/index.hml
+++ /dev/null
@@ -1,19 +0,0 @@
-/*
- * Copyright (c) 2022 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-
- {{ $t('strings.hello') }} {{ title }}
-
-
diff --git a/storage/storagefileurijstest/entry/src/main/js/MainAbility/pages/index/index.js b/storage/storagefileurijstest/entry/src/main/js/MainAbility/pages/index/index.js
deleted file mode 100644
index f086298302bd6362b079bf99cf40dfa1e00d85e9..0000000000000000000000000000000000000000
--- a/storage/storagefileurijstest/entry/src/main/js/MainAbility/pages/index/index.js
+++ /dev/null
@@ -1,22 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-export default {
- data: {
- title: ""
- },
- onInit() {
- this.title = this.$t('strings.world');
- }
-}
diff --git a/storage/storagefileurijstest/entry/src/ohosTest/config.json b/storage/storagefileurijstest/entry/src/ohosTest/config.json
deleted file mode 100644
index 0b3914a2c9a344fa35d55f67a33a6bac1efd61de..0000000000000000000000000000000000000000
--- a/storage/storagefileurijstest/entry/src/ohosTest/config.json
+++ /dev/null
@@ -1,69 +0,0 @@
-{
- "app":{
- "bundleName":"ohos.acts.storage.fileuri",
- "vendor":"example",
- "version":{
- "code":1000000,
- "name":"1.0.0"
- }
- },
- "deviceConfig":{
-
- },
- "module":{
- "package":"ohos.acts.storage.fileuri_test",
- "name":".entry_test",
- "mainAbility":".TestAbility",
- "deviceType": [
- "tablet",
- "default"
- ],
- "testRunner":{
- "name":"OpenHarmonyTestRunner",
- "srcPath":"TestRunner"
- },
- "distro":{
- "deliveryWithInstall":true,
- "installationFree":true,
- "moduleName":"entry_test",
- "moduleType":"feature"
- },
- "abilities":[
- {
- "description":"$string:TestAbility_desc",
- "formsEnabled":false,
- "icon":"$media:icon",
- "label":"$string:TestAbility_label",
- "launchType":"standard",
- "name":".TestAbility",
- "orientation":"unspecified",
- "skills":[
- {
- "actions":[
- "action.system.home"
- ],
- "entities":[
- "entity.system.home"
- ]
- }
- ],
- "srcLanguage":"js",
- "srcPath":"TestAbility",
- "type":"page",
- "visible":true
- }
- ],
- "js":[
- {
- "name":".TestAbility",
- "pages":[
- "pages/index/index"
- ],
- "window":{
- "autoDesignWidth":false,
- "designWidth":720
- }
- }
- ]
- }
-}
\ No newline at end of file
diff --git a/storage/storagefileurijstest/entry/src/ohosTest/resources/base/media/icon.png b/storage/storagefileurijstest/entry/src/ohosTest/resources/base/media/icon.png
deleted file mode 100644
index ce307a8827bd75456441ceb57d530e4c8d45d36c..0000000000000000000000000000000000000000
Binary files a/storage/storagefileurijstest/entry/src/ohosTest/resources/base/media/icon.png and /dev/null differ
diff --git a/storage/storagefileurijstest/hvigor/hvigor-config.json5 b/storage/storagefileurijstest/hvigor/hvigor-config.json5
deleted file mode 100644
index d1ed6c3c0cb895265a376515209a0575aeb7d898..0000000000000000000000000000000000000000
--- a/storage/storagefileurijstest/hvigor/hvigor-config.json5
+++ /dev/null
@@ -1,20 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-{
- "hvigorVersion": "2.0.0",
- "dependencies": {
- "@ohos/hvigor-ohos-plugin": "2.0.0"
- }
-}
diff --git a/storage/storagefileurijstest/hvigor/hvigor-wrapper.js b/storage/storagefileurijstest/hvigor/hvigor-wrapper.js
deleted file mode 100644
index 2507619ca768432ff3fb806441f29eff47a4c4f0..0000000000000000000000000000000000000000
--- a/storage/storagefileurijstest/hvigor/hvigor-wrapper.js
+++ /dev/null
@@ -1,16 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-"use strict";var e=require("fs"),t=require("path"),n=require("os"),r=require("crypto"),u=require("child_process"),o=require("constants"),i=require("stream"),s=require("util"),c=require("assert"),a=require("tty"),l=require("zlib"),f=require("net");function d(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var D=d(e),p=d(t),E=d(n),m=d(r),h=d(u),y=d(o),C=d(i),F=d(s),g=d(c),A=d(a),v=d(l),S=d(f),w="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{},O={},b={},_={},B=w&&w.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(_,"__esModule",{value:!0}),_.isMac=_.isLinux=_.isWindows=void 0;const P=B(E.default),k="Windows_NT",x="Linux",N="Darwin";_.isWindows=function(){return P.default.type()===k},_.isLinux=function(){return P.default.type()===x},_.isMac=function(){return P.default.type()===N};var I={},T=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),R=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),M=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)"default"!==n&&Object.prototype.hasOwnProperty.call(e,n)&&T(t,e,n);return R(t,e),t};Object.defineProperty(I,"__esModule",{value:!0}),I.hash=void 0;const L=M(m.default);I.hash=function(e,t="md5"){return L.createHash(t).update(e,"utf-8").digest("hex")},function(e){var t=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),n=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),r=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var r={};if(null!=e)for(var u in e)"default"!==u&&Object.prototype.hasOwnProperty.call(e,u)&&t(r,e,u);return n(r,e),r};Object.defineProperty(e,"__esModule",{value:!0}),e.HVIGOR_BOOT_JS_FILE_PATH=e.HVIGOR_PROJECT_DEPENDENCY_PACKAGE_JSON_PATH=e.HVIGOR_PROJECT_DEPENDENCIES_HOME=e.HVIGOR_PROJECT_WRAPPER_HOME=e.HVIGOR_PROJECT_NAME=e.HVIGOR_PROJECT_ROOT_DIR=e.HVIGOR_PROJECT_CACHES_HOME=e.HVIGOR_PNPM_STORE_PATH=e.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH=e.HVIGOR_WRAPPER_TOOLS_HOME=e.HVIGOR_USER_HOME=e.DEFAULT_PACKAGE_JSON=e.DEFAULT_HVIGOR_CONFIG_JSON_FILE_NAME=e.PNPM=e.HVIGOR=e.NPM_TOOL=e.PNPM_TOOL=e.HVIGOR_ENGINE_PACKAGE_NAME=void 0;const u=r(p.default),o=r(E.default),i=_,s=I;e.HVIGOR_ENGINE_PACKAGE_NAME="@ohos/hvigor",e.PNPM_TOOL=(0,i.isWindows)()?"pnpm.cmd":"pnpm",e.NPM_TOOL=(0,i.isWindows)()?"npm.cmd":"npm",e.HVIGOR="hvigor",e.PNPM="pnpm",e.DEFAULT_HVIGOR_CONFIG_JSON_FILE_NAME="hvigor-config.json5",e.DEFAULT_PACKAGE_JSON="package.json",e.HVIGOR_USER_HOME=u.resolve(o.homedir(),".hvigor"),e.HVIGOR_WRAPPER_TOOLS_HOME=u.resolve(e.HVIGOR_USER_HOME,"wrapper","tools"),e.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH=u.resolve(e.HVIGOR_WRAPPER_TOOLS_HOME,"node_modules",".bin",e.PNPM_TOOL),e.HVIGOR_PNPM_STORE_PATH=u.resolve(e.HVIGOR_USER_HOME,"caches"),e.HVIGOR_PROJECT_CACHES_HOME=u.resolve(e.HVIGOR_USER_HOME,"project_caches"),e.HVIGOR_PROJECT_ROOT_DIR=process.cwd(),e.HVIGOR_PROJECT_NAME=u.basename((0,s.hash)(e.HVIGOR_PROJECT_ROOT_DIR)),e.HVIGOR_PROJECT_WRAPPER_HOME=u.resolve(e.HVIGOR_PROJECT_ROOT_DIR,e.HVIGOR),e.HVIGOR_PROJECT_DEPENDENCIES_HOME=u.resolve(e.HVIGOR_PROJECT_CACHES_HOME,e.HVIGOR_PROJECT_NAME,"workspace"),e.HVIGOR_PROJECT_DEPENDENCY_PACKAGE_JSON_PATH=u.resolve(e.HVIGOR_PROJECT_DEPENDENCIES_HOME,e.DEFAULT_PACKAGE_JSON),e.HVIGOR_BOOT_JS_FILE_PATH=u.resolve(e.HVIGOR_PROJECT_DEPENDENCIES_HOME,"node_modules","@ohos","hvigor","bin","hvigor.js")}(b);var j={},$={};Object.defineProperty($,"__esModule",{value:!0}),$.logInfoPrintConsole=$.logErrorAndExit=void 0,$.logErrorAndExit=function(e){e instanceof Error?console.error(e.message):console.error(e),process.exit(-1)},$.logInfoPrintConsole=function(e){console.log(e)};var H=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),J=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),G=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)"default"!==n&&Object.prototype.hasOwnProperty.call(e,n)&&H(t,e,n);return J(t,e),t},V=w&&w.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(j,"__esModule",{value:!0}),j.isFileExists=j.offlinePluginConversion=j.executeCommand=j.getNpmPath=j.hasNpmPackInPaths=void 0;const U=h.default,W=G(p.default),z=b,K=$,q=V(D.default);j.hasNpmPackInPaths=function(e,t){try{return require.resolve(e,{paths:[...t]}),!0}catch(e){return!1}},j.getNpmPath=function(){const e=process.execPath;return W.join(W.dirname(e),z.NPM_TOOL)},j.executeCommand=function(e,t,n){0!==(0,U.spawnSync)(e,t,n).status&&(0,K.logErrorAndExit)(`Error: ${e} ${t} execute failed.See above for details.`)},j.offlinePluginConversion=function(e,t){return t.startsWith("file:")||t.endsWith(".tgz")?W.resolve(e,z.HVIGOR,t.replace("file:","")):t},j.isFileExists=function(e){return q.default.existsSync(e)&&q.default.statSync(e).isFile()},function(e){var t=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),n=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),r=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var r={};if(null!=e)for(var u in e)"default"!==u&&Object.prototype.hasOwnProperty.call(e,u)&&t(r,e,u);return n(r,e),r},u=w&&w.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(e,"__esModule",{value:!0}),e.executeInstallPnpm=e.isPnpmAvailable=e.environmentHandler=e.checkNpmConifg=e.PNPM_VERSION=void 0;const o=r(D.default),i=b,s=j,c=r(p.default),a=$,l=h.default,f=u(E.default);e.PNPM_VERSION="7.30.0",e.checkNpmConifg=function(){const e=c.resolve(i.HVIGOR_PROJECT_ROOT_DIR,".npmrc"),t=c.resolve(f.default.homedir(),".npmrc");if((0,s.isFileExists)(e)||(0,s.isFileExists)(t))return;const n=(0,s.getNpmPath)(),r=(0,l.spawnSync)(n,["config","get","prefix"],{cwd:i.HVIGOR_PROJECT_ROOT_DIR});if(0!==r.status||!r.stdout)return void(0,a.logErrorAndExit)("Error: The hvigor depends on the npmrc file. Configure the npmrc file first.");const u=c.resolve(`${r.stdout}`.replace(/[\r\n]/gi,""),".npmrc");(0,s.isFileExists)(u)||(0,a.logErrorAndExit)("Error: The hvigor depends on the npmrc file. Configure the npmrc file first.")},e.environmentHandler=function(){process.env["npm_config_update-notifier"]="false"},e.isPnpmAvailable=function(){return!!o.existsSync(i.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH)&&(0,s.hasNpmPackInPaths)("pnpm",[i.HVIGOR_WRAPPER_TOOLS_HOME])},e.executeInstallPnpm=function(){(0,a.logInfoPrintConsole)(`Installing pnpm@${e.PNPM_VERSION}...`);const t=(0,s.getNpmPath)();!function(){const t=c.resolve(i.HVIGOR_WRAPPER_TOOLS_HOME,i.DEFAULT_PACKAGE_JSON);try{o.existsSync(i.HVIGOR_WRAPPER_TOOLS_HOME)||o.mkdirSync(i.HVIGOR_WRAPPER_TOOLS_HOME,{recursive:!0});const n={dependencies:{}};n.dependencies[i.PNPM]=e.PNPM_VERSION,o.writeFileSync(t,JSON.stringify(n))}catch(e){(0,a.logErrorAndExit)(`Error: EPERM: operation not permitted,create ${t} failed.`)}}(),(0,s.executeCommand)(t,["install","pnpm"],{cwd:i.HVIGOR_WRAPPER_TOOLS_HOME,stdio:["inherit","inherit","inherit"],env:process.env}),(0,a.logInfoPrintConsole)("Pnpm install success.")}}(O);var Y={},X={},Z={},Q={};Object.defineProperty(Q,"__esModule",{value:!0}),Q.Unicode=void 0;class ee{}Q.Unicode=ee,ee.Space_Separator=/[\u1680\u2000-\u200A\u202F\u205F\u3000]/,ee.ID_Start=/[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u05D0-\u05EA\u05F0-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u0860-\u086A\u08A0-\u08B4\u08B6-\u08BD\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u09FC\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0AF9\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58-\u0C5A\u0C60\u0C61\u0C80\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D54-\u0D56\u0D5F-\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1711\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1877\u1880-\u1884\u1887-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1C80-\u1C88\u1CE9-\u1CEC\u1CEE-\u1CF1\u1CF5\u1CF6\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005-\u3007\u3021-\u3029\u3031-\u3035\u3038-\u303C\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312E\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FEA\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6EF\uA717-\uA71F\uA722-\uA788\uA78B-\uA7AE\uA7B0-\uA7B7\uA7F7-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA8FD\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uA9E0-\uA9E4\uA9E6-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB65\uAB70-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD40-\uDD74\uDE80-\uDE9C\uDEA0-\uDED0\uDF00-\uDF1F\uDF2D-\uDF4A\uDF50-\uDF75\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDCB0-\uDCD3\uDCD8-\uDCFB\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDCE0-\uDCF2\uDCF4\uDCF5\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00\uDE10-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE4\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48\uDC80-\uDCB2\uDCC0-\uDCF2]|\uD804[\uDC03-\uDC37\uDC83-\uDCAF\uDCD0-\uDCE8\uDD03-\uDD26\uDD50-\uDD72\uDD76\uDD83-\uDDB2\uDDC1-\uDDC4\uDDDA\uDDDC\uDE00-\uDE11\uDE13-\uDE2B\uDE80-\uDE86\uDE88\uDE8A-\uDE8D\uDE8F-\uDE9D\uDE9F-\uDEA8\uDEB0-\uDEDE\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3D\uDF50\uDF5D-\uDF61]|\uD805[\uDC00-\uDC34\uDC47-\uDC4A\uDC80-\uDCAF\uDCC4\uDCC5\uDCC7\uDD80-\uDDAE\uDDD8-\uDDDB\uDE00-\uDE2F\uDE44\uDE80-\uDEAA\uDF00-\uDF19]|\uD806[\uDCA0-\uDCDF\uDCFF\uDE00\uDE0B-\uDE32\uDE3A\uDE50\uDE5C-\uDE83\uDE86-\uDE89\uDEC0-\uDEF8]|\uD807[\uDC00-\uDC08\uDC0A-\uDC2E\uDC40\uDC72-\uDC8F\uDD00-\uDD06\uDD08\uDD09\uDD0B-\uDD30\uDD46]|\uD808[\uDC00-\uDF99]|\uD809[\uDC00-\uDC6E\uDC80-\uDD43]|[\uD80C\uD81C-\uD820\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD811[\uDC00-\uDE46]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDED0-\uDEED\uDF00-\uDF2F\uDF40-\uDF43\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50\uDF93-\uDF9F\uDFE0\uDFE1]|\uD821[\uDC00-\uDFEC]|\uD822[\uDC00-\uDEF2]|\uD82C[\uDC00-\uDD1E\uDD70-\uDEFB]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB]|\uD83A[\uDC00-\uDCC4\uDD00-\uDD43]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0]|\uD87E[\uDC00-\uDE1D]/,ee.ID_Continue=/[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0300-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u0483-\u0487\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u0591-\u05BD\u05BF\u05C1\u05C2\u05C4\u05C5\u05C7\u05D0-\u05EA\u05F0-\u05F2\u0610-\u061A\u0620-\u0669\u066E-\u06D3\u06D5-\u06DC\u06DF-\u06E8\u06EA-\u06FC\u06FF\u0710-\u074A\u074D-\u07B1\u07C0-\u07F5\u07FA\u0800-\u082D\u0840-\u085B\u0860-\u086A\u08A0-\u08B4\u08B6-\u08BD\u08D4-\u08E1\u08E3-\u0963\u0966-\u096F\u0971-\u0983\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BC-\u09C4\u09C7\u09C8\u09CB-\u09CE\u09D7\u09DC\u09DD\u09DF-\u09E3\u09E6-\u09F1\u09FC\u0A01-\u0A03\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A3C\u0A3E-\u0A42\u0A47\u0A48\u0A4B-\u0A4D\u0A51\u0A59-\u0A5C\u0A5E\u0A66-\u0A75\u0A81-\u0A83\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABC-\u0AC5\u0AC7-\u0AC9\u0ACB-\u0ACD\u0AD0\u0AE0-\u0AE3\u0AE6-\u0AEF\u0AF9-\u0AFF\u0B01-\u0B03\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3C-\u0B44\u0B47\u0B48\u0B4B-\u0B4D\u0B56\u0B57\u0B5C\u0B5D\u0B5F-\u0B63\u0B66-\u0B6F\u0B71\u0B82\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BBE-\u0BC2\u0BC6-\u0BC8\u0BCA-\u0BCD\u0BD0\u0BD7\u0BE6-\u0BEF\u0C00-\u0C03\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D-\u0C44\u0C46-\u0C48\u0C4A-\u0C4D\u0C55\u0C56\u0C58-\u0C5A\u0C60-\u0C63\u0C66-\u0C6F\u0C80-\u0C83\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBC-\u0CC4\u0CC6-\u0CC8\u0CCA-\u0CCD\u0CD5\u0CD6\u0CDE\u0CE0-\u0CE3\u0CE6-\u0CEF\u0CF1\u0CF2\u0D00-\u0D03\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D44\u0D46-\u0D48\u0D4A-\u0D4E\u0D54-\u0D57\u0D5F-\u0D63\u0D66-\u0D6F\u0D7A-\u0D7F\u0D82\u0D83\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0DCA\u0DCF-\u0DD4\u0DD6\u0DD8-\u0DDF\u0DE6-\u0DEF\u0DF2\u0DF3\u0E01-\u0E3A\u0E40-\u0E4E\u0E50-\u0E59\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB9\u0EBB-\u0EBD\u0EC0-\u0EC4\u0EC6\u0EC8-\u0ECD\u0ED0-\u0ED9\u0EDC-\u0EDF\u0F00\u0F18\u0F19\u0F20-\u0F29\u0F35\u0F37\u0F39\u0F3E-\u0F47\u0F49-\u0F6C\u0F71-\u0F84\u0F86-\u0F97\u0F99-\u0FBC\u0FC6\u1000-\u1049\u1050-\u109D\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u135D-\u135F\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1714\u1720-\u1734\u1740-\u1753\u1760-\u176C\u176E-\u1770\u1772\u1773\u1780-\u17D3\u17D7\u17DC\u17DD\u17E0-\u17E9\u180B-\u180D\u1810-\u1819\u1820-\u1877\u1880-\u18AA\u18B0-\u18F5\u1900-\u191E\u1920-\u192B\u1930-\u193B\u1946-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u19D0-\u19D9\u1A00-\u1A1B\u1A20-\u1A5E\u1A60-\u1A7C\u1A7F-\u1A89\u1A90-\u1A99\u1AA7\u1AB0-\u1ABD\u1B00-\u1B4B\u1B50-\u1B59\u1B6B-\u1B73\u1B80-\u1BF3\u1C00-\u1C37\u1C40-\u1C49\u1C4D-\u1C7D\u1C80-\u1C88\u1CD0-\u1CD2\u1CD4-\u1CF9\u1D00-\u1DF9\u1DFB-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u203F\u2040\u2054\u2071\u207F\u2090-\u209C\u20D0-\u20DC\u20E1\u20E5-\u20F0\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D7F-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2DE0-\u2DFF\u2E2F\u3005-\u3007\u3021-\u302F\u3031-\u3035\u3038-\u303C\u3041-\u3096\u3099\u309A\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312E\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FEA\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA62B\uA640-\uA66F\uA674-\uA67D\uA67F-\uA6F1\uA717-\uA71F\uA722-\uA788\uA78B-\uA7AE\uA7B0-\uA7B7\uA7F7-\uA827\uA840-\uA873\uA880-\uA8C5\uA8D0-\uA8D9\uA8E0-\uA8F7\uA8FB\uA8FD\uA900-\uA92D\uA930-\uA953\uA960-\uA97C\uA980-\uA9C0\uA9CF-\uA9D9\uA9E0-\uA9FE\uAA00-\uAA36\uAA40-\uAA4D\uAA50-\uAA59\uAA60-\uAA76\uAA7A-\uAAC2\uAADB-\uAADD\uAAE0-\uAAEF\uAAF2-\uAAF6\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB65\uAB70-\uABEA\uABEC\uABED\uABF0-\uABF9\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE00-\uFE0F\uFE20-\uFE2F\uFE33\uFE34\uFE4D-\uFE4F\uFE70-\uFE74\uFE76-\uFEFC\uFF10-\uFF19\uFF21-\uFF3A\uFF3F\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD40-\uDD74\uDDFD\uDE80-\uDE9C\uDEA0-\uDED0\uDEE0\uDF00-\uDF1F\uDF2D-\uDF4A\uDF50-\uDF7A\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDCA0-\uDCA9\uDCB0-\uDCD3\uDCD8-\uDCFB\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDCE0-\uDCF2\uDCF4\uDCF5\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00-\uDE03\uDE05\uDE06\uDE0C-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE38-\uDE3A\uDE3F\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE6\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48\uDC80-\uDCB2\uDCC0-\uDCF2]|\uD804[\uDC00-\uDC46\uDC66-\uDC6F\uDC7F-\uDCBA\uDCD0-\uDCE8\uDCF0-\uDCF9\uDD00-\uDD34\uDD36-\uDD3F\uDD50-\uDD73\uDD76\uDD80-\uDDC4\uDDCA-\uDDCC\uDDD0-\uDDDA\uDDDC\uDE00-\uDE11\uDE13-\uDE37\uDE3E\uDE80-\uDE86\uDE88\uDE8A-\uDE8D\uDE8F-\uDE9D\uDE9F-\uDEA8\uDEB0-\uDEEA\uDEF0-\uDEF9\uDF00-\uDF03\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3C-\uDF44\uDF47\uDF48\uDF4B-\uDF4D\uDF50\uDF57\uDF5D-\uDF63\uDF66-\uDF6C\uDF70-\uDF74]|\uD805[\uDC00-\uDC4A\uDC50-\uDC59\uDC80-\uDCC5\uDCC7\uDCD0-\uDCD9\uDD80-\uDDB5\uDDB8-\uDDC0\uDDD8-\uDDDD\uDE00-\uDE40\uDE44\uDE50-\uDE59\uDE80-\uDEB7\uDEC0-\uDEC9\uDF00-\uDF19\uDF1D-\uDF2B\uDF30-\uDF39]|\uD806[\uDCA0-\uDCE9\uDCFF\uDE00-\uDE3E\uDE47\uDE50-\uDE83\uDE86-\uDE99\uDEC0-\uDEF8]|\uD807[\uDC00-\uDC08\uDC0A-\uDC36\uDC38-\uDC40\uDC50-\uDC59\uDC72-\uDC8F\uDC92-\uDCA7\uDCA9-\uDCB6\uDD00-\uDD06\uDD08\uDD09\uDD0B-\uDD36\uDD3A\uDD3C\uDD3D\uDD3F-\uDD47\uDD50-\uDD59]|\uD808[\uDC00-\uDF99]|\uD809[\uDC00-\uDC6E\uDC80-\uDD43]|[\uD80C\uD81C-\uD820\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD811[\uDC00-\uDE46]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDE60-\uDE69\uDED0-\uDEED\uDEF0-\uDEF4\uDF00-\uDF36\uDF40-\uDF43\uDF50-\uDF59\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50-\uDF7E\uDF8F-\uDF9F\uDFE0\uDFE1]|\uD821[\uDC00-\uDFEC]|\uD822[\uDC00-\uDEF2]|\uD82C[\uDC00-\uDD1E\uDD70-\uDEFB]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99\uDC9D\uDC9E]|\uD834[\uDD65-\uDD69\uDD6D-\uDD72\uDD7B-\uDD82\uDD85-\uDD8B\uDDAA-\uDDAD\uDE42-\uDE44]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB\uDFCE-\uDFFF]|\uD836[\uDE00-\uDE36\uDE3B-\uDE6C\uDE75\uDE84\uDE9B-\uDE9F\uDEA1-\uDEAF]|\uD838[\uDC00-\uDC06\uDC08-\uDC18\uDC1B-\uDC21\uDC23\uDC24\uDC26-\uDC2A]|\uD83A[\uDC00-\uDCC4\uDCD0-\uDCD6\uDD00-\uDD4A\uDD50-\uDD59]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0]|\uD87E[\uDC00-\uDE1D]|\uDB40[\uDD00-\uDDEF]/,Object.defineProperty(Z,"__esModule",{value:!0}),Z.JudgeUtil=void 0;const te=Q;Z.JudgeUtil=class{static isIgnoreChar(e){return"string"==typeof e&&("\t"===e||"\v"===e||"\f"===e||" "===e||" "===e||"\ufeff"===e||"\n"===e||"\r"===e||"\u2028"===e||"\u2029"===e)}static isSpaceSeparator(e){return"string"==typeof e&&te.Unicode.Space_Separator.test(e)}static isIdStartChar(e){return"string"==typeof e&&(e>="a"&&e<="z"||e>="A"&&e<="Z"||"$"===e||"_"===e||te.Unicode.ID_Start.test(e))}static isIdContinueChar(e){return"string"==typeof e&&(e>="a"&&e<="z"||e>="A"&&e<="Z"||e>="0"&&e<="9"||"$"===e||"_"===e||""===e||""===e||te.Unicode.ID_Continue.test(e))}static isDigitWithoutZero(e){return/[1-9]/.test(e)}static isDigit(e){return"string"==typeof e&&/[0-9]/.test(e)}static isHexDigit(e){return"string"==typeof e&&/[0-9A-Fa-f]/.test(e)}};var ne={},re={fromCallback:function(e){return Object.defineProperty((function(...t){if("function"!=typeof t[t.length-1])return new Promise(((n,r)=>{e.call(this,...t,((e,t)=>null!=e?r(e):n(t)))}));e.apply(this,t)}),"name",{value:e.name})},fromPromise:function(e){return Object.defineProperty((function(...t){const n=t[t.length-1];if("function"!=typeof n)return e.apply(this,t);e.apply(this,t.slice(0,-1)).then((e=>n(null,e)),n)}),"name",{value:e.name})}},ue=y.default,oe=process.cwd,ie=null,se=process.env.GRACEFUL_FS_PLATFORM||process.platform;process.cwd=function(){return ie||(ie=oe.call(process)),ie};try{process.cwd()}catch(e){}if("function"==typeof process.chdir){var ce=process.chdir;process.chdir=function(e){ie=null,ce.call(process,e)},Object.setPrototypeOf&&Object.setPrototypeOf(process.chdir,ce)}var ae=function(e){ue.hasOwnProperty("O_SYMLINK")&&process.version.match(/^v0\.6\.[0-2]|^v0\.5\./)&&function(e){e.lchmod=function(t,n,r){e.open(t,ue.O_WRONLY|ue.O_SYMLINK,n,(function(t,u){t?r&&r(t):e.fchmod(u,n,(function(t){e.close(u,(function(e){r&&r(t||e)}))}))}))},e.lchmodSync=function(t,n){var r,u=e.openSync(t,ue.O_WRONLY|ue.O_SYMLINK,n),o=!0;try{r=e.fchmodSync(u,n),o=!1}finally{if(o)try{e.closeSync(u)}catch(e){}else e.closeSync(u)}return r}}(e);e.lutimes||function(e){ue.hasOwnProperty("O_SYMLINK")&&e.futimes?(e.lutimes=function(t,n,r,u){e.open(t,ue.O_SYMLINK,(function(t,o){t?u&&u(t):e.futimes(o,n,r,(function(t){e.close(o,(function(e){u&&u(t||e)}))}))}))},e.lutimesSync=function(t,n,r){var u,o=e.openSync(t,ue.O_SYMLINK),i=!0;try{u=e.futimesSync(o,n,r),i=!1}finally{if(i)try{e.closeSync(o)}catch(e){}else e.closeSync(o)}return u}):e.futimes&&(e.lutimes=function(e,t,n,r){r&&process.nextTick(r)},e.lutimesSync=function(){})}(e);e.chown=r(e.chown),e.fchown=r(e.fchown),e.lchown=r(e.lchown),e.chmod=t(e.chmod),e.fchmod=t(e.fchmod),e.lchmod=t(e.lchmod),e.chownSync=u(e.chownSync),e.fchownSync=u(e.fchownSync),e.lchownSync=u(e.lchownSync),e.chmodSync=n(e.chmodSync),e.fchmodSync=n(e.fchmodSync),e.lchmodSync=n(e.lchmodSync),e.stat=o(e.stat),e.fstat=o(e.fstat),e.lstat=o(e.lstat),e.statSync=i(e.statSync),e.fstatSync=i(e.fstatSync),e.lstatSync=i(e.lstatSync),e.chmod&&!e.lchmod&&(e.lchmod=function(e,t,n){n&&process.nextTick(n)},e.lchmodSync=function(){});e.chown&&!e.lchown&&(e.lchown=function(e,t,n,r){r&&process.nextTick(r)},e.lchownSync=function(){});"win32"===se&&(e.rename="function"!=typeof e.rename?e.rename:function(t){function n(n,r,u){var o=Date.now(),i=0;t(n,r,(function s(c){if(c&&("EACCES"===c.code||"EPERM"===c.code||"EBUSY"===c.code)&&Date.now()-o<6e4)return setTimeout((function(){e.stat(r,(function(e,o){e&&"ENOENT"===e.code?t(n,r,s):u(c)}))}),i),void(i<100&&(i+=10));u&&u(c)}))}return Object.setPrototypeOf&&Object.setPrototypeOf(n,t),n}(e.rename));function t(t){return t?function(n,r,u){return t.call(e,n,r,(function(e){s(e)&&(e=null),u&&u.apply(this,arguments)}))}:t}function n(t){return t?function(n,r){try{return t.call(e,n,r)}catch(e){if(!s(e))throw e}}:t}function r(t){return t?function(n,r,u,o){return t.call(e,n,r,u,(function(e){s(e)&&(e=null),o&&o.apply(this,arguments)}))}:t}function u(t){return t?function(n,r,u){try{return t.call(e,n,r,u)}catch(e){if(!s(e))throw e}}:t}function o(t){return t?function(n,r,u){function o(e,t){t&&(t.uid<0&&(t.uid+=4294967296),t.gid<0&&(t.gid+=4294967296)),u&&u.apply(this,arguments)}return"function"==typeof r&&(u=r,r=null),r?t.call(e,n,r,o):t.call(e,n,o)}:t}function i(t){return t?function(n,r){var u=r?t.call(e,n,r):t.call(e,n);return u&&(u.uid<0&&(u.uid+=4294967296),u.gid<0&&(u.gid+=4294967296)),u}:t}function s(e){return!e||("ENOSYS"===e.code||!(process.getuid&&0===process.getuid()||"EINVAL"!==e.code&&"EPERM"!==e.code))}e.read="function"!=typeof e.read?e.read:function(t){function n(n,r,u,o,i,s){var c;if(s&&"function"==typeof s){var a=0;c=function(l,f,d){if(l&&"EAGAIN"===l.code&&a<10)return a++,t.call(e,n,r,u,o,i,c);s.apply(this,arguments)}}return t.call(e,n,r,u,o,i,c)}return Object.setPrototypeOf&&Object.setPrototypeOf(n,t),n}(e.read),e.readSync="function"!=typeof e.readSync?e.readSync:(c=e.readSync,function(t,n,r,u,o){for(var i=0;;)try{return c.call(e,t,n,r,u,o)}catch(e){if("EAGAIN"===e.code&&i<10){i++;continue}throw e}});var c};var le=C.default.Stream,fe=function(e){return{ReadStream:function t(n,r){if(!(this instanceof t))return new t(n,r);le.call(this);var u=this;this.path=n,this.fd=null,this.readable=!0,this.paused=!1,this.flags="r",this.mode=438,this.bufferSize=65536,r=r||{};for(var o=Object.keys(r),i=0,s=o.length;ithis.end)throw new Error("start must be <= end");this.pos=this.start}if(null!==this.fd)return void process.nextTick((function(){u._read()}));e.open(this.path,this.flags,this.mode,(function(e,t){if(e)return u.emit("error",e),void(u.readable=!1);u.fd=t,u.emit("open",t),u._read()}))},WriteStream:function t(n,r){if(!(this instanceof t))return new t(n,r);le.call(this),this.path=n,this.fd=null,this.writable=!0,this.flags="w",this.encoding="binary",this.mode=438,this.bytesWritten=0,r=r||{};for(var u=Object.keys(r),o=0,i=u.length;o= zero");this.pos=this.start}this.busy=!1,this._queue=[],null===this.fd&&(this._open=e.open,this._queue.push([this._open,this.path,this.flags,this.mode,void 0]),this.flush())}}};var de=function(e){if(null===e||"object"!=typeof e)return e;if(e instanceof Object)var t={__proto__:De(e)};else t=Object.create(null);return Object.getOwnPropertyNames(e).forEach((function(n){Object.defineProperty(t,n,Object.getOwnPropertyDescriptor(e,n))})),t},De=Object.getPrototypeOf||function(e){return e.__proto__};var pe,Ee,me=D.default,he=ae,ye=fe,Ce=de,Fe=F.default;function ge(e,t){Object.defineProperty(e,pe,{get:function(){return t}})}"function"==typeof Symbol&&"function"==typeof Symbol.for?(pe=Symbol.for("graceful-fs.queue"),Ee=Symbol.for("graceful-fs.previous")):(pe="___graceful-fs.queue",Ee="___graceful-fs.previous");var Ae=function(){};if(Fe.debuglog?Ae=Fe.debuglog("gfs4"):/\bgfs4\b/i.test(process.env.NODE_DEBUG||"")&&(Ae=function(){var e=Fe.format.apply(Fe,arguments);e="GFS4: "+e.split(/\n/).join("\nGFS4: "),console.error(e)}),!me[pe]){var ve=w[pe]||[];ge(me,ve),me.close=function(e){function t(t,n){return e.call(me,t,(function(e){e||_e(),"function"==typeof n&&n.apply(this,arguments)}))}return Object.defineProperty(t,Ee,{value:e}),t}(me.close),me.closeSync=function(e){function t(t){e.apply(me,arguments),_e()}return Object.defineProperty(t,Ee,{value:e}),t}(me.closeSync),/\bgfs4\b/i.test(process.env.NODE_DEBUG||"")&&process.on("exit",(function(){Ae(me[pe]),g.default.equal(me[pe].length,0)}))}w[pe]||ge(w,me[pe]);var Se,we=Oe(Ce(me));function Oe(e){he(e),e.gracefulify=Oe,e.createReadStream=function(t,n){return new e.ReadStream(t,n)},e.createWriteStream=function(t,n){return new e.WriteStream(t,n)};var t=e.readFile;e.readFile=function(e,n,r){"function"==typeof n&&(r=n,n=null);return function e(n,r,u,o){return t(n,r,(function(t){!t||"EMFILE"!==t.code&&"ENFILE"!==t.code?"function"==typeof u&&u.apply(this,arguments):be([e,[n,r,u],t,o||Date.now(),Date.now()])}))}(e,n,r)};var n=e.writeFile;e.writeFile=function(e,t,r,u){"function"==typeof r&&(u=r,r=null);return function e(t,r,u,o,i){return n(t,r,u,(function(n){!n||"EMFILE"!==n.code&&"ENFILE"!==n.code?"function"==typeof o&&o.apply(this,arguments):be([e,[t,r,u,o],n,i||Date.now(),Date.now()])}))}(e,t,r,u)};var r=e.appendFile;r&&(e.appendFile=function(e,t,n,u){"function"==typeof n&&(u=n,n=null);return function e(t,n,u,o,i){return r(t,n,u,(function(r){!r||"EMFILE"!==r.code&&"ENFILE"!==r.code?"function"==typeof o&&o.apply(this,arguments):be([e,[t,n,u,o],r,i||Date.now(),Date.now()])}))}(e,t,n,u)});var u=e.copyFile;u&&(e.copyFile=function(e,t,n,r){"function"==typeof n&&(r=n,n=0);return function e(t,n,r,o,i){return u(t,n,r,(function(u){!u||"EMFILE"!==u.code&&"ENFILE"!==u.code?"function"==typeof o&&o.apply(this,arguments):be([e,[t,n,r,o],u,i||Date.now(),Date.now()])}))}(e,t,n,r)});var o=e.readdir;e.readdir=function(e,t,n){"function"==typeof t&&(n=t,t=null);var r=i.test(process.version)?function(e,t,n,r){return o(e,u(e,t,n,r))}:function(e,t,n,r){return o(e,t,u(e,t,n,r))};return r(e,t,n);function u(e,t,n,u){return function(o,i){!o||"EMFILE"!==o.code&&"ENFILE"!==o.code?(i&&i.sort&&i.sort(),"function"==typeof n&&n.call(this,o,i)):be([r,[e,t,n],o,u||Date.now(),Date.now()])}}};var i=/^v[0-5]\./;if("v0.8"===process.version.substr(0,4)){var s=ye(e);d=s.ReadStream,D=s.WriteStream}var c=e.ReadStream;c&&(d.prototype=Object.create(c.prototype),d.prototype.open=function(){var e=this;E(e.path,e.flags,e.mode,(function(t,n){t?(e.autoClose&&e.destroy(),e.emit("error",t)):(e.fd=n,e.emit("open",n),e.read())}))});var a=e.WriteStream;a&&(D.prototype=Object.create(a.prototype),D.prototype.open=function(){var e=this;E(e.path,e.flags,e.mode,(function(t,n){t?(e.destroy(),e.emit("error",t)):(e.fd=n,e.emit("open",n))}))}),Object.defineProperty(e,"ReadStream",{get:function(){return d},set:function(e){d=e},enumerable:!0,configurable:!0}),Object.defineProperty(e,"WriteStream",{get:function(){return D},set:function(e){D=e},enumerable:!0,configurable:!0});var l=d;Object.defineProperty(e,"FileReadStream",{get:function(){return l},set:function(e){l=e},enumerable:!0,configurable:!0});var f=D;function d(e,t){return this instanceof d?(c.apply(this,arguments),this):d.apply(Object.create(d.prototype),arguments)}function D(e,t){return this instanceof D?(a.apply(this,arguments),this):D.apply(Object.create(D.prototype),arguments)}Object.defineProperty(e,"FileWriteStream",{get:function(){return f},set:function(e){f=e},enumerable:!0,configurable:!0});var p=e.open;function E(e,t,n,r){return"function"==typeof n&&(r=n,n=null),function e(t,n,r,u,o){return p(t,n,r,(function(i,s){!i||"EMFILE"!==i.code&&"ENFILE"!==i.code?"function"==typeof u&&u.apply(this,arguments):be([e,[t,n,r,u],i,o||Date.now(),Date.now()])}))}(e,t,n,r)}return e.open=E,e}function be(e){Ae("ENQUEUE",e[0].name,e[1]),me[pe].push(e),Be()}function _e(){for(var e=Date.now(),t=0;t2&&(me[pe][t][3]=e,me[pe][t][4]=e);Be()}function Be(){if(clearTimeout(Se),Se=void 0,0!==me[pe].length){var e=me[pe].shift(),t=e[0],n=e[1],r=e[2],u=e[3],o=e[4];if(void 0===u)Ae("RETRY",t.name,n),t.apply(null,n);else if(Date.now()-u>=6e4){Ae("TIMEOUT",t.name,n);var i=n.pop();"function"==typeof i&&i.call(null,r)}else{var s=Date.now()-o,c=Math.max(o-u,1);s>=Math.min(1.2*c,100)?(Ae("RETRY",t.name,n),t.apply(null,n.concat([u]))):me[pe].push(e)}void 0===Se&&(Se=setTimeout(Be,0))}}process.env.TEST_GRACEFUL_FS_GLOBAL_PATCH&&!me.__patched&&(we=Oe(me),me.__patched=!0),function(e){const t=re.fromCallback,n=we,r=["access","appendFile","chmod","chown","close","copyFile","fchmod","fchown","fdatasync","fstat","fsync","ftruncate","futimes","lchmod","lchown","link","lstat","mkdir","mkdtemp","open","opendir","readdir","readFile","readlink","realpath","rename","rm","rmdir","stat","symlink","truncate","unlink","utimes","writeFile"].filter((e=>"function"==typeof n[e]));Object.assign(e,n),r.forEach((r=>{e[r]=t(n[r])})),e.realpath.native=t(n.realpath.native),e.exists=function(e,t){return"function"==typeof t?n.exists(e,t):new Promise((t=>n.exists(e,t)))},e.read=function(e,t,r,u,o,i){return"function"==typeof i?n.read(e,t,r,u,o,i):new Promise(((i,s)=>{n.read(e,t,r,u,o,((e,t,n)=>{if(e)return s(e);i({bytesRead:t,buffer:n})}))}))},e.write=function(e,t,...r){return"function"==typeof r[r.length-1]?n.write(e,t,...r):new Promise(((u,o)=>{n.write(e,t,...r,((e,t,n)=>{if(e)return o(e);u({bytesWritten:t,buffer:n})}))}))},"function"==typeof n.writev&&(e.writev=function(e,t,...r){return"function"==typeof r[r.length-1]?n.writev(e,t,...r):new Promise(((u,o)=>{n.writev(e,t,...r,((e,t,n)=>{if(e)return o(e);u({bytesWritten:t,buffers:n})}))}))})}(ne);var Pe={},ke={};const xe=p.default;ke.checkPath=function(e){if("win32"===process.platform){if(/[<>:"|?*]/.test(e.replace(xe.parse(e).root,""))){const t=new Error(`Path contains invalid characters: ${e}`);throw t.code="EINVAL",t}}};const Ne=ne,{checkPath:Ie}=ke,Te=e=>"number"==typeof e?e:{mode:511,...e}.mode;Pe.makeDir=async(e,t)=>(Ie(e),Ne.mkdir(e,{mode:Te(t),recursive:!0})),Pe.makeDirSync=(e,t)=>(Ie(e),Ne.mkdirSync(e,{mode:Te(t),recursive:!0}));const Re=re.fromPromise,{makeDir:Me,makeDirSync:Le}=Pe,je=Re(Me);var $e={mkdirs:je,mkdirsSync:Le,mkdirp:je,mkdirpSync:Le,ensureDir:je,ensureDirSync:Le};const He=re.fromPromise,Je=ne;var Ge={pathExists:He((function(e){return Je.access(e).then((()=>!0)).catch((()=>!1))})),pathExistsSync:Je.existsSync};const Ve=we;var Ue=function(e,t,n,r){Ve.open(e,"r+",((e,u)=>{if(e)return r(e);Ve.futimes(u,t,n,(e=>{Ve.close(u,(t=>{r&&r(e||t)}))}))}))},We=function(e,t,n){const r=Ve.openSync(e,"r+");return Ve.futimesSync(r,t,n),Ve.closeSync(r)};const ze=ne,Ke=p.default,qe=F.default;function Ye(e,t,n){const r=n.dereference?e=>ze.stat(e,{bigint:!0}):e=>ze.lstat(e,{bigint:!0});return Promise.all([r(e),r(t).catch((e=>{if("ENOENT"===e.code)return null;throw e}))]).then((([e,t])=>({srcStat:e,destStat:t})))}function Xe(e,t){return t.ino&&t.dev&&t.ino===e.ino&&t.dev===e.dev}function Ze(e,t){const n=Ke.resolve(e).split(Ke.sep).filter((e=>e)),r=Ke.resolve(t).split(Ke.sep).filter((e=>e));return n.reduce(((e,t,n)=>e&&r[n]===t),!0)}function Qe(e,t,n){return`Cannot ${n} '${e}' to a subdirectory of itself, '${t}'.`}var et={checkPaths:function(e,t,n,r,u){qe.callbackify(Ye)(e,t,r,((r,o)=>{if(r)return u(r);const{srcStat:i,destStat:s}=o;if(s){if(Xe(i,s)){const r=Ke.basename(e),o=Ke.basename(t);return"move"===n&&r!==o&&r.toLowerCase()===o.toLowerCase()?u(null,{srcStat:i,destStat:s,isChangingCase:!0}):u(new Error("Source and destination must not be the same."))}if(i.isDirectory()&&!s.isDirectory())return u(new Error(`Cannot overwrite non-directory '${t}' with directory '${e}'.`));if(!i.isDirectory()&&s.isDirectory())return u(new Error(`Cannot overwrite directory '${t}' with non-directory '${e}'.`))}return i.isDirectory()&&Ze(e,t)?u(new Error(Qe(e,t,n))):u(null,{srcStat:i,destStat:s})}))},checkPathsSync:function(e,t,n,r){const{srcStat:u,destStat:o}=function(e,t,n){let r;const u=n.dereference?e=>ze.statSync(e,{bigint:!0}):e=>ze.lstatSync(e,{bigint:!0}),o=u(e);try{r=u(t)}catch(e){if("ENOENT"===e.code)return{srcStat:o,destStat:null};throw e}return{srcStat:o,destStat:r}}(e,t,r);if(o){if(Xe(u,o)){const r=Ke.basename(e),i=Ke.basename(t);if("move"===n&&r!==i&&r.toLowerCase()===i.toLowerCase())return{srcStat:u,destStat:o,isChangingCase:!0};throw new Error("Source and destination must not be the same.")}if(u.isDirectory()&&!o.isDirectory())throw new Error(`Cannot overwrite non-directory '${t}' with directory '${e}'.`);if(!u.isDirectory()&&o.isDirectory())throw new Error(`Cannot overwrite directory '${t}' with non-directory '${e}'.`)}if(u.isDirectory()&&Ze(e,t))throw new Error(Qe(e,t,n));return{srcStat:u,destStat:o}},checkParentPaths:function e(t,n,r,u,o){const i=Ke.resolve(Ke.dirname(t)),s=Ke.resolve(Ke.dirname(r));if(s===i||s===Ke.parse(s).root)return o();ze.stat(s,{bigint:!0},((i,c)=>i?"ENOENT"===i.code?o():o(i):Xe(n,c)?o(new Error(Qe(t,r,u))):e(t,n,s,u,o)))},checkParentPathsSync:function e(t,n,r,u){const o=Ke.resolve(Ke.dirname(t)),i=Ke.resolve(Ke.dirname(r));if(i===o||i===Ke.parse(i).root)return;let s;try{s=ze.statSync(i,{bigint:!0})}catch(e){if("ENOENT"===e.code)return;throw e}if(Xe(n,s))throw new Error(Qe(t,r,u));return e(t,n,i,u)},isSrcSubdir:Ze,areIdentical:Xe};const tt=we,nt=p.default,rt=$e.mkdirs,ut=Ge.pathExists,ot=Ue,it=et;function st(e,t,n,r,u){const o=nt.dirname(n);ut(o,((i,s)=>i?u(i):s?at(e,t,n,r,u):void rt(o,(o=>o?u(o):at(e,t,n,r,u)))))}function ct(e,t,n,r,u,o){Promise.resolve(u.filter(n,r)).then((i=>i?e(t,n,r,u,o):o()),(e=>o(e)))}function at(e,t,n,r,u){(r.dereference?tt.stat:tt.lstat)(t,((o,i)=>o?u(o):i.isDirectory()?function(e,t,n,r,u,o){return t?Dt(n,r,u,o):function(e,t,n,r,u){tt.mkdir(n,(o=>{if(o)return u(o);Dt(t,n,r,(t=>t?u(t):dt(n,e,u)))}))}(e.mode,n,r,u,o)}(i,e,t,n,r,u):i.isFile()||i.isCharacterDevice()||i.isBlockDevice()?function(e,t,n,r,u,o){return t?function(e,t,n,r,u){if(!r.overwrite)return r.errorOnExist?u(new Error(`'${n}' already exists`)):u();tt.unlink(n,(o=>o?u(o):lt(e,t,n,r,u)))}(e,n,r,u,o):lt(e,n,r,u,o)}(i,e,t,n,r,u):i.isSymbolicLink()?function(e,t,n,r,u){tt.readlink(t,((t,o)=>t?u(t):(r.dereference&&(o=nt.resolve(process.cwd(),o)),e?void tt.readlink(n,((t,i)=>t?"EINVAL"===t.code||"UNKNOWN"===t.code?tt.symlink(o,n,u):u(t):(r.dereference&&(i=nt.resolve(process.cwd(),i)),it.isSrcSubdir(o,i)?u(new Error(`Cannot copy '${o}' to a subdirectory of itself, '${i}'.`)):e.isDirectory()&&it.isSrcSubdir(i,o)?u(new Error(`Cannot overwrite '${i}' with '${o}'.`)):function(e,t,n){tt.unlink(t,(r=>r?n(r):tt.symlink(e,t,n)))}(o,n,u)))):tt.symlink(o,n,u))))}(e,t,n,r,u):i.isSocket()?u(new Error(`Cannot copy a socket file: ${t}`)):i.isFIFO()?u(new Error(`Cannot copy a FIFO pipe: ${t}`)):u(new Error(`Unknown file: ${t}`))))}function lt(e,t,n,r,u){tt.copyFile(t,n,(o=>o?u(o):r.preserveTimestamps?function(e,t,n,r){if(function(e){return 0==(128&e)}(e))return function(e,t,n){return dt(e,128|t,n)}(n,e,(u=>u?r(u):ft(e,t,n,r)));return ft(e,t,n,r)}(e.mode,t,n,u):dt(n,e.mode,u)))}function ft(e,t,n,r){!function(e,t,n){tt.stat(e,((e,r)=>e?n(e):ot(t,r.atime,r.mtime,n)))}(t,n,(t=>t?r(t):dt(n,e,r)))}function dt(e,t,n){return tt.chmod(e,t,n)}function Dt(e,t,n,r){tt.readdir(e,((u,o)=>u?r(u):pt(o,e,t,n,r)))}function pt(e,t,n,r,u){const o=e.pop();return o?function(e,t,n,r,u,o){const i=nt.join(n,t),s=nt.join(r,t);it.checkPaths(i,s,"copy",u,((t,c)=>{if(t)return o(t);const{destStat:a}=c;!function(e,t,n,r,u){r.filter?ct(at,e,t,n,r,u):at(e,t,n,r,u)}(a,i,s,u,(t=>t?o(t):pt(e,n,r,u,o)))}))}(e,o,t,n,r,u):u()}var Et=function(e,t,n,r){"function"!=typeof n||r?"function"==typeof n&&(n={filter:n}):(r=n,n={}),r=r||function(){},(n=n||{}).clobber=!("clobber"in n)||!!n.clobber,n.overwrite="overwrite"in n?!!n.overwrite:n.clobber,n.preserveTimestamps&&"ia32"===process.arch&&console.warn("fs-extra: Using the preserveTimestamps option in 32-bit node is not recommended;\n\n see https://github.com/jprichardson/node-fs-extra/issues/269"),it.checkPaths(e,t,"copy",n,((u,o)=>{if(u)return r(u);const{srcStat:i,destStat:s}=o;it.checkParentPaths(e,i,t,"copy",(u=>u?r(u):n.filter?ct(st,s,e,t,n,r):st(s,e,t,n,r)))}))};const mt=we,ht=p.default,yt=$e.mkdirsSync,Ct=We,Ft=et;function gt(e,t,n,r){const u=(r.dereference?mt.statSync:mt.lstatSync)(t);if(u.isDirectory())return function(e,t,n,r,u){return t?St(n,r,u):function(e,t,n,r){return mt.mkdirSync(n),St(t,n,r),vt(n,e)}(e.mode,n,r,u)}(u,e,t,n,r);if(u.isFile()||u.isCharacterDevice()||u.isBlockDevice())return function(e,t,n,r,u){return t?function(e,t,n,r){if(r.overwrite)return mt.unlinkSync(n),At(e,t,n,r);if(r.errorOnExist)throw new Error(`'${n}' already exists`)}(e,n,r,u):At(e,n,r,u)}(u,e,t,n,r);if(u.isSymbolicLink())return function(e,t,n,r){let u=mt.readlinkSync(t);r.dereference&&(u=ht.resolve(process.cwd(),u));if(e){let e;try{e=mt.readlinkSync(n)}catch(e){if("EINVAL"===e.code||"UNKNOWN"===e.code)return mt.symlinkSync(u,n);throw e}if(r.dereference&&(e=ht.resolve(process.cwd(),e)),Ft.isSrcSubdir(u,e))throw new Error(`Cannot copy '${u}' to a subdirectory of itself, '${e}'.`);if(mt.statSync(n).isDirectory()&&Ft.isSrcSubdir(e,u))throw new Error(`Cannot overwrite '${e}' with '${u}'.`);return function(e,t){return mt.unlinkSync(t),mt.symlinkSync(e,t)}(u,n)}return mt.symlinkSync(u,n)}(e,t,n,r);if(u.isSocket())throw new Error(`Cannot copy a socket file: ${t}`);if(u.isFIFO())throw new Error(`Cannot copy a FIFO pipe: ${t}`);throw new Error(`Unknown file: ${t}`)}function At(e,t,n,r){return mt.copyFileSync(t,n),r.preserveTimestamps&&function(e,t,n){(function(e){return 0==(128&e)})(e)&&function(e,t){vt(e,128|t)}(n,e);(function(e,t){const n=mt.statSync(e);Ct(t,n.atime,n.mtime)})(t,n)}(e.mode,t,n),vt(n,e.mode)}function vt(e,t){return mt.chmodSync(e,t)}function St(e,t,n){mt.readdirSync(e).forEach((r=>function(e,t,n,r){const u=ht.join(t,e),o=ht.join(n,e),{destStat:i}=Ft.checkPathsSync(u,o,"copy",r);return function(e,t,n,r){if(!r.filter||r.filter(t,n))return gt(e,t,n,r)}(i,u,o,r)}(r,e,t,n)))}var wt=function(e,t,n){"function"==typeof n&&(n={filter:n}),(n=n||{}).clobber=!("clobber"in n)||!!n.clobber,n.overwrite="overwrite"in n?!!n.overwrite:n.clobber,n.preserveTimestamps&&"ia32"===process.arch&&console.warn("fs-extra: Using the preserveTimestamps option in 32-bit node is not recommended;\n\n see https://github.com/jprichardson/node-fs-extra/issues/269");const{srcStat:r,destStat:u}=Ft.checkPathsSync(e,t,"copy",n);return Ft.checkParentPathsSync(e,r,t,"copy"),function(e,t,n,r){if(r.filter&&!r.filter(t,n))return;const u=ht.dirname(n);mt.existsSync(u)||yt(u);return gt(e,t,n,r)}(u,e,t,n)};var Ot={copy:(0,re.fromCallback)(Et),copySync:wt};const bt=we,_t=p.default,Bt=g.default,Pt="win32"===process.platform;function kt(e){["unlink","chmod","stat","lstat","rmdir","readdir"].forEach((t=>{e[t]=e[t]||bt[t],e[t+="Sync"]=e[t]||bt[t]})),e.maxBusyTries=e.maxBusyTries||3}function xt(e,t,n){let r=0;"function"==typeof t&&(n=t,t={}),Bt(e,"rimraf: missing path"),Bt.strictEqual(typeof e,"string","rimraf: path should be a string"),Bt.strictEqual(typeof n,"function","rimraf: callback function required"),Bt(t,"rimraf: invalid options argument provided"),Bt.strictEqual(typeof t,"object","rimraf: options should be object"),kt(t),Nt(e,t,(function u(o){if(o){if(("EBUSY"===o.code||"ENOTEMPTY"===o.code||"EPERM"===o.code)&&rNt(e,t,u)),100*r)}"ENOENT"===o.code&&(o=null)}n(o)}))}function Nt(e,t,n){Bt(e),Bt(t),Bt("function"==typeof n),t.lstat(e,((r,u)=>r&&"ENOENT"===r.code?n(null):r&&"EPERM"===r.code&&Pt?It(e,t,r,n):u&&u.isDirectory()?Rt(e,t,r,n):void t.unlink(e,(r=>{if(r){if("ENOENT"===r.code)return n(null);if("EPERM"===r.code)return Pt?It(e,t,r,n):Rt(e,t,r,n);if("EISDIR"===r.code)return Rt(e,t,r,n)}return n(r)}))))}function It(e,t,n,r){Bt(e),Bt(t),Bt("function"==typeof r),t.chmod(e,438,(u=>{u?r("ENOENT"===u.code?null:n):t.stat(e,((u,o)=>{u?r("ENOENT"===u.code?null:n):o.isDirectory()?Rt(e,t,n,r):t.unlink(e,r)}))}))}function Tt(e,t,n){let r;Bt(e),Bt(t);try{t.chmodSync(e,438)}catch(e){if("ENOENT"===e.code)return;throw n}try{r=t.statSync(e)}catch(e){if("ENOENT"===e.code)return;throw n}r.isDirectory()?Lt(e,t,n):t.unlinkSync(e)}function Rt(e,t,n,r){Bt(e),Bt(t),Bt("function"==typeof r),t.rmdir(e,(u=>{!u||"ENOTEMPTY"!==u.code&&"EEXIST"!==u.code&&"EPERM"!==u.code?u&&"ENOTDIR"===u.code?r(n):r(u):function(e,t,n){Bt(e),Bt(t),Bt("function"==typeof n),t.readdir(e,((r,u)=>{if(r)return n(r);let o,i=u.length;if(0===i)return t.rmdir(e,n);u.forEach((r=>{xt(_t.join(e,r),t,(r=>{if(!o)return r?n(o=r):void(0==--i&&t.rmdir(e,n))}))}))}))}(e,t,r)}))}function Mt(e,t){let n;kt(t=t||{}),Bt(e,"rimraf: missing path"),Bt.strictEqual(typeof e,"string","rimraf: path should be a string"),Bt(t,"rimraf: missing options"),Bt.strictEqual(typeof t,"object","rimraf: options should be object");try{n=t.lstatSync(e)}catch(n){if("ENOENT"===n.code)return;"EPERM"===n.code&&Pt&&Tt(e,t,n)}try{n&&n.isDirectory()?Lt(e,t,null):t.unlinkSync(e)}catch(n){if("ENOENT"===n.code)return;if("EPERM"===n.code)return Pt?Tt(e,t,n):Lt(e,t,n);if("EISDIR"!==n.code)throw n;Lt(e,t,n)}}function Lt(e,t,n){Bt(e),Bt(t);try{t.rmdirSync(e)}catch(r){if("ENOTDIR"===r.code)throw n;if("ENOTEMPTY"===r.code||"EEXIST"===r.code||"EPERM"===r.code)!function(e,t){if(Bt(e),Bt(t),t.readdirSync(e).forEach((n=>Mt(_t.join(e,n),t))),!Pt){return t.rmdirSync(e,t)}{const n=Date.now();do{try{return t.rmdirSync(e,t)}catch{}}while(Date.now()-n<500)}}(e,t);else if("ENOENT"!==r.code)throw r}}var jt=xt;xt.sync=Mt;const $t=we,Ht=re.fromCallback,Jt=jt;var Gt={remove:Ht((function(e,t){if($t.rm)return $t.rm(e,{recursive:!0,force:!0},t);Jt(e,t)})),removeSync:function(e){if($t.rmSync)return $t.rmSync(e,{recursive:!0,force:!0});Jt.sync(e)}};const Vt=re.fromPromise,Ut=ne,Wt=p.default,zt=$e,Kt=Gt,qt=Vt((async function(e){let t;try{t=await Ut.readdir(e)}catch{return zt.mkdirs(e)}return Promise.all(t.map((t=>Kt.remove(Wt.join(e,t)))))}));function Yt(e){let t;try{t=Ut.readdirSync(e)}catch{return zt.mkdirsSync(e)}t.forEach((t=>{t=Wt.join(e,t),Kt.removeSync(t)}))}var Xt={emptyDirSync:Yt,emptydirSync:Yt,emptyDir:qt,emptydir:qt};const Zt=re.fromCallback,Qt=p.default,en=we,tn=$e;var nn={createFile:Zt((function(e,t){function n(){en.writeFile(e,"",(e=>{if(e)return t(e);t()}))}en.stat(e,((r,u)=>{if(!r&&u.isFile())return t();const o=Qt.dirname(e);en.stat(o,((e,r)=>{if(e)return"ENOENT"===e.code?tn.mkdirs(o,(e=>{if(e)return t(e);n()})):t(e);r.isDirectory()?n():en.readdir(o,(e=>{if(e)return t(e)}))}))}))})),createFileSync:function(e){let t;try{t=en.statSync(e)}catch{}if(t&&t.isFile())return;const n=Qt.dirname(e);try{en.statSync(n).isDirectory()||en.readdirSync(n)}catch(e){if(!e||"ENOENT"!==e.code)throw e;tn.mkdirsSync(n)}en.writeFileSync(e,"")}};const rn=re.fromCallback,un=p.default,on=we,sn=$e,cn=Ge.pathExists,{areIdentical:an}=et;var ln={createLink:rn((function(e,t,n){function r(e,t){on.link(e,t,(e=>{if(e)return n(e);n(null)}))}on.lstat(t,((u,o)=>{on.lstat(e,((u,i)=>{if(u)return u.message=u.message.replace("lstat","ensureLink"),n(u);if(o&&an(i,o))return n(null);const s=un.dirname(t);cn(s,((u,o)=>u?n(u):o?r(e,t):void sn.mkdirs(s,(u=>{if(u)return n(u);r(e,t)}))))}))}))})),createLinkSync:function(e,t){let n;try{n=on.lstatSync(t)}catch{}try{const t=on.lstatSync(e);if(n&&an(t,n))return}catch(e){throw e.message=e.message.replace("lstat","ensureLink"),e}const r=un.dirname(t);return on.existsSync(r)||sn.mkdirsSync(r),on.linkSync(e,t)}};const fn=p.default,dn=we,Dn=Ge.pathExists;var pn={symlinkPaths:function(e,t,n){if(fn.isAbsolute(e))return dn.lstat(e,(t=>t?(t.message=t.message.replace("lstat","ensureSymlink"),n(t)):n(null,{toCwd:e,toDst:e})));{const r=fn.dirname(t),u=fn.join(r,e);return Dn(u,((t,o)=>t?n(t):o?n(null,{toCwd:u,toDst:e}):dn.lstat(e,(t=>t?(t.message=t.message.replace("lstat","ensureSymlink"),n(t)):n(null,{toCwd:e,toDst:fn.relative(r,e)})))))}},symlinkPathsSync:function(e,t){let n;if(fn.isAbsolute(e)){if(n=dn.existsSync(e),!n)throw new Error("absolute srcpath does not exist");return{toCwd:e,toDst:e}}{const r=fn.dirname(t),u=fn.join(r,e);if(n=dn.existsSync(u),n)return{toCwd:u,toDst:e};if(n=dn.existsSync(e),!n)throw new Error("relative srcpath does not exist");return{toCwd:e,toDst:fn.relative(r,e)}}}};const En=we;var mn={symlinkType:function(e,t,n){if(n="function"==typeof t?t:n,t="function"!=typeof t&&t)return n(null,t);En.lstat(e,((e,r)=>{if(e)return n(null,"file");t=r&&r.isDirectory()?"dir":"file",n(null,t)}))},symlinkTypeSync:function(e,t){let n;if(t)return t;try{n=En.lstatSync(e)}catch{return"file"}return n&&n.isDirectory()?"dir":"file"}};const hn=re.fromCallback,yn=p.default,Cn=ne,Fn=$e.mkdirs,gn=$e.mkdirsSync,An=pn.symlinkPaths,vn=pn.symlinkPathsSync,Sn=mn.symlinkType,wn=mn.symlinkTypeSync,On=Ge.pathExists,{areIdentical:bn}=et;function _n(e,t,n,r){An(e,t,((u,o)=>{if(u)return r(u);e=o.toDst,Sn(o.toCwd,n,((n,u)=>{if(n)return r(n);const o=yn.dirname(t);On(o,((n,i)=>n?r(n):i?Cn.symlink(e,t,u,r):void Fn(o,(n=>{if(n)return r(n);Cn.symlink(e,t,u,r)}))))}))}))}var Bn={createSymlink:hn((function(e,t,n,r){r="function"==typeof n?n:r,n="function"!=typeof n&&n,Cn.lstat(t,((u,o)=>{!u&&o.isSymbolicLink()?Promise.all([Cn.stat(e),Cn.stat(t)]).then((([u,o])=>{if(bn(u,o))return r(null);_n(e,t,n,r)})):_n(e,t,n,r)}))})),createSymlinkSync:function(e,t,n){let r;try{r=Cn.lstatSync(t)}catch{}if(r&&r.isSymbolicLink()){const n=Cn.statSync(e),r=Cn.statSync(t);if(bn(n,r))return}const u=vn(e,t);e=u.toDst,n=wn(u.toCwd,n);const o=yn.dirname(t);return Cn.existsSync(o)||gn(o),Cn.symlinkSync(e,t,n)}};const{createFile:Pn,createFileSync:kn}=nn,{createLink:xn,createLinkSync:Nn}=ln,{createSymlink:In,createSymlinkSync:Tn}=Bn;var Rn={createFile:Pn,createFileSync:kn,ensureFile:Pn,ensureFileSync:kn,createLink:xn,createLinkSync:Nn,ensureLink:xn,ensureLinkSync:Nn,createSymlink:In,createSymlinkSync:Tn,ensureSymlink:In,ensureSymlinkSync:Tn};var Mn={stringify:function(e,{EOL:t="\n",finalEOL:n=!0,replacer:r=null,spaces:u}={}){const o=n?t:"";return JSON.stringify(e,r,u).replace(/\n/g,t)+o},stripBom:function(e){return Buffer.isBuffer(e)&&(e=e.toString("utf8")),e.replace(/^\uFEFF/,"")}};let Ln;try{Ln=we}catch(e){Ln=D.default}const jn=re,{stringify:$n,stripBom:Hn}=Mn;const Jn=jn.fromPromise((async function(e,t={}){"string"==typeof t&&(t={encoding:t});const n=t.fs||Ln,r=!("throws"in t)||t.throws;let u,o=await jn.fromCallback(n.readFile)(e,t);o=Hn(o);try{u=JSON.parse(o,t?t.reviver:null)}catch(t){if(r)throw t.message=`${e}: ${t.message}`,t;return null}return u}));const Gn=jn.fromPromise((async function(e,t,n={}){const r=n.fs||Ln,u=$n(t,n);await jn.fromCallback(r.writeFile)(e,u,n)}));const Vn={readFile:Jn,readFileSync:function(e,t={}){"string"==typeof t&&(t={encoding:t});const n=t.fs||Ln,r=!("throws"in t)||t.throws;try{let r=n.readFileSync(e,t);return r=Hn(r),JSON.parse(r,t.reviver)}catch(t){if(r)throw t.message=`${e}: ${t.message}`,t;return null}},writeFile:Gn,writeFileSync:function(e,t,n={}){const r=n.fs||Ln,u=$n(t,n);return r.writeFileSync(e,u,n)}};var Un={readJson:Vn.readFile,readJsonSync:Vn.readFileSync,writeJson:Vn.writeFile,writeJsonSync:Vn.writeFileSync};const Wn=re.fromCallback,zn=we,Kn=p.default,qn=$e,Yn=Ge.pathExists;var Xn={outputFile:Wn((function(e,t,n,r){"function"==typeof n&&(r=n,n="utf8");const u=Kn.dirname(e);Yn(u,((o,i)=>o?r(o):i?zn.writeFile(e,t,n,r):void qn.mkdirs(u,(u=>{if(u)return r(u);zn.writeFile(e,t,n,r)}))))})),outputFileSync:function(e,...t){const n=Kn.dirname(e);if(zn.existsSync(n))return zn.writeFileSync(e,...t);qn.mkdirsSync(n),zn.writeFileSync(e,...t)}};const{stringify:Zn}=Mn,{outputFile:Qn}=Xn;var er=async function(e,t,n={}){const r=Zn(t,n);await Qn(e,r,n)};const{stringify:tr}=Mn,{outputFileSync:nr}=Xn;var rr=function(e,t,n){const r=tr(t,n);nr(e,r,n)};const ur=re.fromPromise,or=Un;or.outputJson=ur(er),or.outputJsonSync=rr,or.outputJSON=or.outputJson,or.outputJSONSync=or.outputJsonSync,or.writeJSON=or.writeJson,or.writeJSONSync=or.writeJsonSync,or.readJSON=or.readJson,or.readJSONSync=or.readJsonSync;var ir=or;const sr=we,cr=p.default,ar=Ot.copy,lr=Gt.remove,fr=$e.mkdirp,dr=Ge.pathExists,Dr=et;function pr(e,t,n,r,u){return r?Er(e,t,n,u):n?lr(t,(r=>r?u(r):Er(e,t,n,u))):void dr(t,((r,o)=>r?u(r):o?u(new Error("dest already exists.")):Er(e,t,n,u)))}function Er(e,t,n,r){sr.rename(e,t,(u=>u?"EXDEV"!==u.code?r(u):function(e,t,n,r){const u={overwrite:n,errorOnExist:!0};ar(e,t,u,(t=>t?r(t):lr(e,r)))}(e,t,n,r):r()))}var mr=function(e,t,n,r){"function"==typeof n&&(r=n,n={});const u=n.overwrite||n.clobber||!1;Dr.checkPaths(e,t,"move",n,((n,o)=>{if(n)return r(n);const{srcStat:i,isChangingCase:s=!1}=o;Dr.checkParentPaths(e,i,t,"move",(n=>n?r(n):function(e){const t=cr.dirname(e);return cr.parse(t).root===t}(t)?pr(e,t,u,s,r):void fr(cr.dirname(t),(n=>n?r(n):pr(e,t,u,s,r)))))}))};const hr=we,yr=p.default,Cr=Ot.copySync,Fr=Gt.removeSync,gr=$e.mkdirpSync,Ar=et;function vr(e,t,n){try{hr.renameSync(e,t)}catch(r){if("EXDEV"!==r.code)throw r;return function(e,t,n){const r={overwrite:n,errorOnExist:!0};return Cr(e,t,r),Fr(e)}(e,t,n)}}var Sr=function(e,t,n){const r=(n=n||{}).overwrite||n.clobber||!1,{srcStat:u,isChangingCase:o=!1}=Ar.checkPathsSync(e,t,"move",n);return Ar.checkParentPathsSync(e,u,t,"move"),function(e){const t=yr.dirname(e);return yr.parse(t).root===t}(t)||gr(yr.dirname(t)),function(e,t,n,r){if(r)return vr(e,t,n);if(n)return Fr(t),vr(e,t,n);if(hr.existsSync(t))throw new Error("dest already exists.");return vr(e,t,n)}(e,t,r,o)};var wr,Or,br,_r,Br,Pr={move:(0,re.fromCallback)(mr),moveSync:Sr},kr={...ne,...Ot,...Xt,...Rn,...ir,...$e,...Pr,...Xn,...Ge,...Gt},xr={},Nr={exports:{}},Ir={exports:{}};function Tr(){if(Or)return wr;Or=1;var e=1e3,t=60*e,n=60*t,r=24*n,u=7*r,o=365.25*r;function i(e,t,n,r){var u=t>=1.5*n;return Math.round(e/n)+" "+r+(u?"s":"")}return wr=function(s,c){c=c||{};var a=typeof s;if("string"===a&&s.length>0)return function(i){if((i=String(i)).length>100)return;var s=/^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(i);if(!s)return;var c=parseFloat(s[1]);switch((s[2]||"ms").toLowerCase()){case"years":case"year":case"yrs":case"yr":case"y":return c*o;case"weeks":case"week":case"w":return c*u;case"days":case"day":case"d":return c*r;case"hours":case"hour":case"hrs":case"hr":case"h":return c*n;case"minutes":case"minute":case"mins":case"min":case"m":return c*t;case"seconds":case"second":case"secs":case"sec":case"s":return c*e;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return c;default:return}}(s);if("number"===a&&isFinite(s))return c.long?function(u){var o=Math.abs(u);if(o>=r)return i(u,o,r,"day");if(o>=n)return i(u,o,n,"hour");if(o>=t)return i(u,o,t,"minute");if(o>=e)return i(u,o,e,"second");return u+" ms"}(s):function(u){var o=Math.abs(u);if(o>=r)return Math.round(u/r)+"d";if(o>=n)return Math.round(u/n)+"h";if(o>=t)return Math.round(u/t)+"m";if(o>=e)return Math.round(u/e)+"s";return u+"ms"}(s);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(s))}}function Rr(){if(_r)return br;return _r=1,br=function(e){function t(e){let r,u,o,i=null;function s(...e){if(!s.enabled)return;const n=s,u=Number(new Date),o=u-(r||u);n.diff=o,n.prev=r,n.curr=u,r=u,e[0]=t.coerce(e[0]),"string"!=typeof e[0]&&e.unshift("%O");let i=0;e[0]=e[0].replace(/%([a-zA-Z%])/g,((r,u)=>{if("%%"===r)return"%";i++;const o=t.formatters[u];if("function"==typeof o){const t=e[i];r=o.call(n,t),e.splice(i,1),i--}return r})),t.formatArgs.call(n,e);(n.log||t.log).apply(n,e)}return s.namespace=e,s.useColors=t.useColors(),s.color=t.selectColor(e),s.extend=n,s.destroy=t.destroy,Object.defineProperty(s,"enabled",{enumerable:!0,configurable:!1,get:()=>null!==i?i:(u!==t.namespaces&&(u=t.namespaces,o=t.enabled(e)),o),set:e=>{i=e}}),"function"==typeof t.init&&t.init(s),s}function n(e,n){const r=t(this.namespace+(void 0===n?":":n)+e);return r.log=this.log,r}function r(e){return e.toString().substring(2,e.toString().length-2).replace(/\.\*\?$/,"*")}return t.debug=t,t.default=t,t.coerce=function(e){if(e instanceof Error)return e.stack||e.message;return e},t.disable=function(){const e=[...t.names.map(r),...t.skips.map(r).map((e=>"-"+e))].join(",");return t.enable(""),e},t.enable=function(e){let n;t.save(e),t.namespaces=e,t.names=[],t.skips=[];const r=("string"==typeof e?e:"").split(/[\s,]+/),u=r.length;for(n=0;n{t[n]=e[n]})),t.names=[],t.skips=[],t.formatters={},t.selectColor=function(e){let n=0;for(let t=0;t{const n=e.startsWith("-")?"":1===e.length?"-":"--",r=t.indexOf(n+e),u=t.indexOf("--");return-1!==r&&(-1===u||r{}),"Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."),t.colors=[6,2,3,4,5,1];try{const e=function(){if($r)return jr;$r=1;const e=E.default,t=A.default,n=Vr(),{env:r}=process;let u;function o(e){return 0!==e&&{level:e,hasBasic:!0,has256:e>=2,has16m:e>=3}}function i(t,o){if(0===u)return 0;if(n("color=16m")||n("color=full")||n("color=truecolor"))return 3;if(n("color=256"))return 2;if(t&&!o&&void 0===u)return 0;const i=u||0;if("dumb"===r.TERM)return i;if("win32"===process.platform){const t=e.release().split(".");return Number(t[0])>=10&&Number(t[2])>=10586?Number(t[2])>=14931?3:2:1}if("CI"in r)return["TRAVIS","CIRCLECI","APPVEYOR","GITLAB_CI","GITHUB_ACTIONS","BUILDKITE"].some((e=>e in r))||"codeship"===r.CI_NAME?1:i;if("TEAMCITY_VERSION"in r)return/^(9\.(0*[1-9]\d*)\.|\d{2,}\.)/.test(r.TEAMCITY_VERSION)?1:0;if("truecolor"===r.COLORTERM)return 3;if("TERM_PROGRAM"in r){const e=parseInt((r.TERM_PROGRAM_VERSION||"").split(".")[0],10);switch(r.TERM_PROGRAM){case"iTerm.app":return e>=3?3:2;case"Apple_Terminal":return 2}}return/-256(color)?$/i.test(r.TERM)?2:/^screen|^xterm|^vt100|^vt220|^rxvt|color|ansi|cygwin|linux/i.test(r.TERM)||"COLORTERM"in r?1:i}return n("no-color")||n("no-colors")||n("color=false")||n("color=never")?u=0:(n("color")||n("colors")||n("color=true")||n("color=always"))&&(u=1),"FORCE_COLOR"in r&&(u="true"===r.FORCE_COLOR?1:"false"===r.FORCE_COLOR?0:0===r.FORCE_COLOR.length?1:Math.min(parseInt(r.FORCE_COLOR,10),3)),jr={supportsColor:function(e){return o(i(e,e&&e.isTTY))},stdout:o(i(!0,t.isatty(1))),stderr:o(i(!0,t.isatty(2)))}}();e&&(e.stderr||e).level>=2&&(t.colors=[20,21,26,27,32,33,38,39,40,41,42,43,44,45,56,57,62,63,68,69,74,75,76,77,78,79,80,81,92,93,98,99,112,113,128,129,134,135,148,149,160,161,162,163,164,165,166,167,168,169,170,171,172,173,178,179,184,185,196,197,198,199,200,201,202,203,204,205,206,207,208,209,214,215,220,221])}catch(e){}t.inspectOpts=Object.keys(process.env).filter((e=>/^debug_/i.test(e))).reduce(((e,t)=>{const n=t.substring(6).toLowerCase().replace(/_([a-z])/g,((e,t)=>t.toUpperCase()));let r=process.env[t];return r=!!/^(yes|on|true|enabled)$/i.test(r)||!/^(no|off|false|disabled)$/i.test(r)&&("null"===r?null:Number(r)),e[n]=r,e}),{}),e.exports=Rr()(t);const{formatters:u}=e.exports;u.o=function(e){return this.inspectOpts.colors=this.useColors,r.inspect(e,this.inspectOpts).split("\n").map((e=>e.trim())).join(" ")},u.O=function(e){return this.inspectOpts.colors=this.useColors,r.inspect(e,this.inspectOpts)}}(Gr,Gr.exports)),Gr.exports}Jr=Nr,"undefined"==typeof process||"renderer"===process.type||!0===process.browser||process.__nwjs?Jr.exports=(Br||(Br=1,function(e,t){t.formatArgs=function(t){if(t[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+t[0]+(this.useColors?"%c ":" ")+"+"+e.exports.humanize(this.diff),!this.useColors)return;const n="color: "+this.color;t.splice(1,0,n,"color: inherit");let r=0,u=0;t[0].replace(/%[a-zA-Z%]/g,(e=>{"%%"!==e&&(r++,"%c"===e&&(u=r))})),t.splice(u,0,n)},t.save=function(e){try{e?t.storage.setItem("debug",e):t.storage.removeItem("debug")}catch(e){}},t.load=function(){let e;try{e=t.storage.getItem("debug")}catch(e){}return!e&&"undefined"!=typeof process&&"env"in process&&(e=process.env.DEBUG),e},t.useColors=function(){return!("undefined"==typeof window||!window.process||"renderer"!==window.process.type&&!window.process.__nwjs)||("undefined"==typeof navigator||!navigator.userAgent||!navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/))&&("undefined"!=typeof document&&document.documentElement&&document.documentElement.style&&document.documentElement.style.WebkitAppearance||"undefined"!=typeof window&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||"undefined"!=typeof navigator&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/)&&parseInt(RegExp.$1,10)>=31||"undefined"!=typeof navigator&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/))},t.storage=function(){try{return localStorage}catch(e){}}(),t.destroy=(()=>{let e=!1;return()=>{e||(e=!0,console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."))}})(),t.colors=["#0000CC","#0000FF","#0033CC","#0033FF","#0066CC","#0066FF","#0099CC","#0099FF","#00CC00","#00CC33","#00CC66","#00CC99","#00CCCC","#00CCFF","#3300CC","#3300FF","#3333CC","#3333FF","#3366CC","#3366FF","#3399CC","#3399FF","#33CC00","#33CC33","#33CC66","#33CC99","#33CCCC","#33CCFF","#6600CC","#6600FF","#6633CC","#6633FF","#66CC00","#66CC33","#9900CC","#9900FF","#9933CC","#9933FF","#99CC00","#99CC33","#CC0000","#CC0033","#CC0066","#CC0099","#CC00CC","#CC00FF","#CC3300","#CC3333","#CC3366","#CC3399","#CC33CC","#CC33FF","#CC6600","#CC6633","#CC9900","#CC9933","#CCCC00","#CCCC33","#FF0000","#FF0033","#FF0066","#FF0099","#FF00CC","#FF00FF","#FF3300","#FF3333","#FF3366","#FF3399","#FF33CC","#FF33FF","#FF6600","#FF6633","#FF9900","#FF9933","#FFCC00","#FFCC33"],t.log=console.debug||console.log||(()=>{}),e.exports=Rr()(t);const{formatters:n}=e.exports;n.j=function(e){try{return JSON.stringify(e)}catch(e){return"[UnexpectedJSONParseError]: "+e.message}}}(Ir,Ir.exports)),Ir.exports):Jr.exports=Ur();var Wr=function(e){return(e=e||{}).circles?function(e){var t=[],n=[];return e.proto?function e(u){if("object"!=typeof u||null===u)return u;if(u instanceof Date)return new Date(u);if(Array.isArray(u))return r(u,e);if(u instanceof Map)return new Map(r(Array.from(u),e));if(u instanceof Set)return new Set(r(Array.from(u),e));var o={};for(var i in t.push(u),n.push(o),u){var s=u[i];if("object"!=typeof s||null===s)o[i]=s;else if(s instanceof Date)o[i]=new Date(s);else if(s instanceof Map)o[i]=new Map(r(Array.from(s),e));else if(s instanceof Set)o[i]=new Set(r(Array.from(s),e));else if(ArrayBuffer.isView(s))o[i]=zr(s);else{var c=t.indexOf(s);o[i]=-1!==c?n[c]:e(s)}}return t.pop(),n.pop(),o}:function e(u){if("object"!=typeof u||null===u)return u;if(u instanceof Date)return new Date(u);if(Array.isArray(u))return r(u,e);if(u instanceof Map)return new Map(r(Array.from(u),e));if(u instanceof Set)return new Set(r(Array.from(u),e));var o={};for(var i in t.push(u),n.push(o),u)if(!1!==Object.hasOwnProperty.call(u,i)){var s=u[i];if("object"!=typeof s||null===s)o[i]=s;else if(s instanceof Date)o[i]=new Date(s);else if(s instanceof Map)o[i]=new Map(r(Array.from(s),e));else if(s instanceof Set)o[i]=new Set(r(Array.from(s),e));else if(ArrayBuffer.isView(s))o[i]=zr(s);else{var c=t.indexOf(s);o[i]=-1!==c?n[c]:e(s)}}return t.pop(),n.pop(),o};function r(e,r){for(var u=Object.keys(e),o=new Array(u.length),i=0;i!e,Qr=e=>e&&"object"==typeof e&&!Array.isArray(e),eu=(e,t,n)=>{(Array.isArray(t)?t:[t]).forEach((t=>{if(t)throw new Error(`Problem with log4js configuration: (${Kr.inspect(e,{depth:5})}) - ${n}`)}))};var tu={configure:e=>{qr("New configuration to be validated: ",e),eu(e,Zr(Qr(e)),"must be an object."),qr(`Calling pre-processing listeners (${Yr.length})`),Yr.forEach((t=>t(e))),qr("Configuration pre-processing finished."),qr(`Calling configuration listeners (${Xr.length})`),Xr.forEach((t=>t(e))),qr("Configuration finished.")},addListener:e=>{Xr.push(e),qr(`Added listener, now ${Xr.length} listeners`)},addPreProcessingListener:e=>{Yr.push(e),qr(`Added pre-processing listener, now ${Yr.length} listeners`)},throwExceptionIf:eu,anObject:Qr,anInteger:e=>e&&"number"==typeof e&&Number.isInteger(e),validIdentifier:e=>/^[A-Za-z][A-Za-z0-9_]*$/g.test(e),not:Zr},nu={exports:{}};!function(e){function t(e,t){for(var n=e.toString();n.length-1?s:c,l=n(u.getHours()),f=n(u.getMinutes()),d=n(u.getSeconds()),D=t(u.getMilliseconds(),3),p=function(e){var t=Math.abs(e),n=String(Math.floor(t/60)),r=String(t%60);return n=("0"+n).slice(-2),r=("0"+r).slice(-2),0===e?"Z":(e<0?"+":"-")+n+":"+r}(u.getTimezoneOffset());return r.replace(/dd/g,o).replace(/MM/g,i).replace(/y{1,4}/g,a).replace(/hh/g,l).replace(/mm/g,f).replace(/ss/g,d).replace(/SSS/g,D).replace(/O/g,p)}function u(e,t,n,r){e["set"+(r?"":"UTC")+t](n)}e.exports=r,e.exports.asString=r,e.exports.parse=function(t,n,r){if(!t)throw new Error("pattern must be supplied");return function(t,n,r){var o=t.indexOf("O")<0,i=!1,s=[{pattern:/y{1,4}/,regexp:"\\d{1,4}",fn:function(e,t){u(e,"FullYear",t,o)}},{pattern:/MM/,regexp:"\\d{1,2}",fn:function(e,t){u(e,"Month",t-1,o),e.getMonth()!==t-1&&(i=!0)}},{pattern:/dd/,regexp:"\\d{1,2}",fn:function(e,t){i&&u(e,"Month",e.getMonth()-1,o),u(e,"Date",t,o)}},{pattern:/hh/,regexp:"\\d{1,2}",fn:function(e,t){u(e,"Hours",t,o)}},{pattern:/mm/,regexp:"\\d\\d",fn:function(e,t){u(e,"Minutes",t,o)}},{pattern:/ss/,regexp:"\\d\\d",fn:function(e,t){u(e,"Seconds",t,o)}},{pattern:/SSS/,regexp:"\\d\\d\\d",fn:function(e,t){u(e,"Milliseconds",t,o)}},{pattern:/O/,regexp:"[+-]\\d{1,2}:?\\d{2}?|Z",fn:function(e,t){t="Z"===t?0:t.replace(":","");var n=Math.abs(t),r=(t>0?-1:1)*(n%100+60*Math.floor(n/100));e.setUTCMinutes(e.getUTCMinutes()+r)}}],c=s.reduce((function(e,t){return t.pattern.test(e.regexp)?(t.index=e.regexp.match(t.pattern).index,e.regexp=e.regexp.replace(t.pattern,"("+t.regexp+")")):t.index=-1,e}),{regexp:t,index:[]}),a=s.filter((function(e){return e.index>-1}));a.sort((function(e,t){return e.index-t.index}));var l=new RegExp(c.regexp).exec(n);if(l){var f=r||e.exports.now();return a.forEach((function(e,t){e.fn(f,l[t+1])})),f}throw new Error("String '"+n+"' could not be parsed as '"+t+"'")}(t,n,r)},e.exports.now=function(){return new Date},e.exports.ISO8601_FORMAT="yyyy-MM-ddThh:mm:ss.SSS",e.exports.ISO8601_WITH_TZ_OFFSET_FORMAT="yyyy-MM-ddThh:mm:ss.SSSO",e.exports.DATETIME_FORMAT="dd MM yyyy hh:mm:ss.SSS",e.exports.ABSOLUTETIME_FORMAT="hh:mm:ss.SSS"}(nu);const ru=nu.exports,uu=E.default,ou=F.default,iu=p.default,su={bold:[1,22],italic:[3,23],underline:[4,24],inverse:[7,27],white:[37,39],grey:[90,39],black:[90,39],blue:[34,39],cyan:[36,39],green:[32,39],magenta:[35,39],red:[91,39],yellow:[33,39]};function cu(e){return e?`[${su[e][0]}m`:""}function au(e){return e?`[${su[e][1]}m`:""}function lu(e,t){return n=ou.format("[%s] [%s] %s - ",ru.asString(e.startTime),e.level.toString(),e.categoryName),cu(r=t)+n+au(r);var n,r}function fu(e){return lu(e)+ou.format(...e.data)}function du(e){return lu(e,e.level.colour)+ou.format(...e.data)}function Du(e){return ou.format(...e.data)}function pu(e){return e.data[0]}function Eu(e,t){const n=/%(-?[0-9]+)?(\.?-?[0-9]+)?([[\]cdhmnprzxXyflos%])(\{([^}]+)\})?|([^%]+)/;function r(e){return e&&e.pid?e.pid.toString():process.pid.toString()}e=e||"%r %p %c - %m%n";const u={c:function(e,t){let n=e.categoryName;if(t){const e=parseInt(t,10),r=n.split(".");ee&&(n=r.slice(-e).join(iu.sep))}return n},l:function(e){return e.lineNumber?`${e.lineNumber}`:""},o:function(e){return e.columnNumber?`${e.columnNumber}`:""},s:function(e){return e.callStack||""}};function o(e,t,n){return u[e](t,n)}function i(e,t,n){let r=e;return r=function(e,t){let n;return e?(n=parseInt(e.substr(1),10),n>0?t.slice(0,n):t.slice(n)):t}(t,r),r=function(e,t){let n;if(e)if("-"===e.charAt(0))for(n=parseInt(e.substr(1),10);t.lengthDu,basic:()=>fu,colored:()=>du,coloured:()=>du,pattern:e=>Eu(e&&e.pattern,e&&e.tokens),dummy:()=>pu};var hu={basicLayout:fu,messagePassThroughLayout:Du,patternLayout:Eu,colouredLayout:du,coloredLayout:du,dummyLayout:pu,addLayout(e,t){mu[e]=t},layout:(e,t)=>mu[e]&&mu[e](t)};const yu=tu,Cu=["white","grey","black","blue","cyan","green","magenta","red","yellow"];class Fu{constructor(e,t,n){this.level=e,this.levelStr=t,this.colour=n}toString(){return this.levelStr}static getLevel(e,t){return e?e instanceof Fu?e:(e instanceof Object&&e.levelStr&&(e=e.levelStr),Fu[e.toString().toUpperCase()]||t):t}static addLevels(e){if(e){Object.keys(e).forEach((t=>{const n=t.toUpperCase();Fu[n]=new Fu(e[t].value,n,e[t].colour);const r=Fu.levels.findIndex((e=>e.levelStr===n));r>-1?Fu.levels[r]=Fu[n]:Fu.levels.push(Fu[n])})),Fu.levels.sort(((e,t)=>e.level-t.level))}}isLessThanOrEqualTo(e){return"string"==typeof e&&(e=Fu.getLevel(e)),this.level<=e.level}isGreaterThanOrEqualTo(e){return"string"==typeof e&&(e=Fu.getLevel(e)),this.level>=e.level}isEqualTo(e){return"string"==typeof e&&(e=Fu.getLevel(e)),this.level===e.level}}Fu.levels=[],Fu.addLevels({ALL:{value:Number.MIN_VALUE,colour:"grey"},TRACE:{value:5e3,colour:"blue"},DEBUG:{value:1e4,colour:"cyan"},INFO:{value:2e4,colour:"green"},WARN:{value:3e4,colour:"yellow"},ERROR:{value:4e4,colour:"red"},FATAL:{value:5e4,colour:"magenta"},MARK:{value:9007199254740992,colour:"grey"},OFF:{value:Number.MAX_VALUE,colour:"grey"}}),yu.addListener((e=>{const t=e.levels;if(t){yu.throwExceptionIf(e,yu.not(yu.anObject(t)),"levels must be an object");Object.keys(t).forEach((n=>{yu.throwExceptionIf(e,yu.not(yu.validIdentifier(n)),`level name "${n}" is not a valid identifier (must start with a letter, only contain A-Z,a-z,0-9,_)`),yu.throwExceptionIf(e,yu.not(yu.anObject(t[n])),`level "${n}" must be an object`),yu.throwExceptionIf(e,yu.not(t[n].value),`level "${n}" must have a 'value' property`),yu.throwExceptionIf(e,yu.not(yu.anInteger(t[n].value)),`level "${n}".value must have an integer value`),yu.throwExceptionIf(e,yu.not(t[n].colour),`level "${n}" must have a 'colour' property`),yu.throwExceptionIf(e,yu.not(Cu.indexOf(t[n].colour)>-1),`level "${n}".colour must be one of ${Cu.join(", ")}`)}))}})),yu.addListener((e=>{Fu.addLevels(e.levels)}));var gu=Fu,Au={exports:{}},vu={};/*! (c) 2020 Andrea Giammarchi */
-const{parse:Su,stringify:wu}=JSON,{keys:Ou}=Object,bu=String,_u="string",Bu={},Pu="object",ku=(e,t)=>t,xu=e=>e instanceof bu?bu(e):e,Nu=(e,t)=>typeof t===_u?new bu(t):t,Iu=(e,t,n,r)=>{const u=[];for(let o=Ou(n),{length:i}=o,s=0;s{const r=bu(t.push(n)-1);return e.set(n,r),r},Ru=(e,t)=>{const n=Su(e,Nu).map(xu),r=n[0],u=t||ku,o=typeof r===Pu&&r?Iu(n,new Set,r,u):r;return u.call({"":o},"",o)};vu.parse=Ru;const Mu=(e,t,n)=>{const r=t&&typeof t===Pu?(e,n)=>""===e||-1Su(Mu(e));vu.fromJSON=e=>Ru(wu(e));const Lu=vu,ju=gu;class $u{constructor(e,t,n,r,u){this.startTime=new Date,this.categoryName=e,this.data=n,this.level=t,this.context=Object.assign({},r),this.pid=process.pid,u&&(this.functionName=u.functionName,this.fileName=u.fileName,this.lineNumber=u.lineNumber,this.columnNumber=u.columnNumber,this.callStack=u.callStack)}serialise(){const e=this.data.map((e=>(e&&e.message&&e.stack&&(e=Object.assign({message:e.message,stack:e.stack},e)),e)));return this.data=e,Lu.stringify(this)}static deserialise(e){let t;try{const n=Lu.parse(e);n.data=n.data.map((e=>{if(e&&e.message&&e.stack){const t=new Error(e);Object.keys(e).forEach((n=>{t[n]=e[n]})),e=t}return e})),t=new $u(n.categoryName,ju.getLevel(n.level.levelStr),n.data,n.context),t.startTime=new Date(n.startTime),t.pid=n.pid,t.cluster=n.cluster}catch(n){t=new $u("log4js",ju.ERROR,["Unable to parse log:",e,"because: ",n])}return t}}var Hu=$u;const Ju=Nr.exports("log4js:clustering"),Gu=Hu,Vu=tu;let Uu=!1,Wu=null;try{Wu=require("cluster")}catch(e){Ju("cluster module not present"),Uu=!0}const zu=[];let Ku=!1,qu="NODE_APP_INSTANCE";const Yu=()=>Ku&&"0"===process.env[qu],Xu=()=>Uu||Wu.isMaster||Yu(),Zu=e=>{zu.forEach((t=>t(e)))},Qu=(e,t)=>{if(Ju("cluster message received from worker ",e,": ",t),e.topic&&e.data&&(t=e,e=void 0),t&&t.topic&&"log4js:message"===t.topic){Ju("received message: ",t.data);const e=Gu.deserialise(t.data);Zu(e)}};Uu||Vu.addListener((e=>{zu.length=0,({pm2:Ku,disableClustering:Uu,pm2InstanceVar:qu="NODE_APP_INSTANCE"}=e),Ju(`clustering disabled ? ${Uu}`),Ju(`cluster.isMaster ? ${Wu&&Wu.isMaster}`),Ju(`pm2 enabled ? ${Ku}`),Ju(`pm2InstanceVar = ${qu}`),Ju(`process.env[${qu}] = ${process.env[qu]}`),Ku&&process.removeListener("message",Qu),Wu&&Wu.removeListener&&Wu.removeListener("message",Qu),Uu||e.disableClustering?Ju("Not listening for cluster messages, because clustering disabled."):Yu()?(Ju("listening for PM2 broadcast messages"),process.on("message",Qu)):Wu.isMaster?(Ju("listening for cluster messages"),Wu.on("message",Qu)):Ju("not listening for messages, because we are not a master process")}));var eo={onlyOnMaster:(e,t)=>Xu()?e():t,isMaster:Xu,send:e=>{Xu()?Zu(e):(Ku||(e.cluster={workerId:Wu.worker.id,worker:process.pid}),process.send({topic:"log4js:message",data:e.serialise()}))},onMessage:e=>{zu.push(e)}},to={};function no(e){if("number"==typeof e&&Number.isInteger(e))return e;const t={K:1024,M:1048576,G:1073741824},n=Object.keys(t),r=e.substr(e.length-1).toLocaleUpperCase(),u=e.substring(0,e.length-1).trim();if(n.indexOf(r)<0||!Number.isInteger(Number(u)))throw Error(`maxLogSize: "${e}" is invalid`);return u*t[r]}function ro(e){return function(e,t){const n=Object.assign({},t);return Object.keys(e).forEach((r=>{n[r]&&(n[r]=e[r](t[r]))})),n}({maxLogSize:no},e)}const uo={file:ro,fileSync:ro};to.modifyConfig=e=>uo[e.type]?uo[e.type](e):e;var oo={};const io=console.log.bind(console);oo.configure=function(e,t){let n=t.colouredLayout;return e.layout&&(n=t.layout(e.layout.type,e.layout)),function(e,t){return n=>{io(e(n,t))}}(n,e.timezoneOffset)};var so={};so.configure=function(e,t){let n=t.colouredLayout;return e.layout&&(n=t.layout(e.layout.type,e.layout)),function(e,t){return n=>{process.stdout.write(`${e(n,t)}\n`)}}(n,e.timezoneOffset)};var co={};co.configure=function(e,t){let n=t.colouredLayout;return e.layout&&(n=t.layout(e.layout.type,e.layout)),function(e,t){return n=>{process.stderr.write(`${e(n,t)}\n`)}}(n,e.timezoneOffset)};var ao={};ao.configure=function(e,t,n,r){const u=n(e.appender);return function(e,t,n,r){const u=r.getLevel(e),o=r.getLevel(t,r.FATAL);return e=>{const t=e.level;t.isGreaterThanOrEqualTo(u)&&t.isLessThanOrEqualTo(o)&&n(e)}}(e.level,e.maxLevel,u,r)};var lo={};const fo=Nr.exports("log4js:categoryFilter");lo.configure=function(e,t,n){const r=n(e.appender);return function(e,t){return"string"==typeof e&&(e=[e]),n=>{fo(`Checking ${n.categoryName} against ${e}`),-1===e.indexOf(n.categoryName)&&(fo("Not excluded, sending to appender"),t(n))}}(e.exclude,r)};var Do={};const po=Nr.exports("log4js:noLogFilter");Do.configure=function(e,t,n){const r=n(e.appender);return function(e,t){return n=>{po(`Checking data: ${n.data} against filters: ${e}`),"string"==typeof e&&(e=[e]),e=e.filter((e=>null!=e&&""!==e));const r=new RegExp(e.join("|"),"i");(0===e.length||n.data.findIndex((e=>r.test(e)))<0)&&(po("Not excluded, sending to appender"),t(n))}}(e.exclude,r)};var Eo={},mo={exports:{}},ho={},yo={fromCallback:function(e){return Object.defineProperty((function(){if("function"!=typeof arguments[arguments.length-1])return new Promise(((t,n)=>{arguments[arguments.length]=(e,r)=>{if(e)return n(e);t(r)},arguments.length++,e.apply(this,arguments)}));e.apply(this,arguments)}),"name",{value:e.name})},fromPromise:function(e){return Object.defineProperty((function(){const t=arguments[arguments.length-1];if("function"!=typeof t)return e.apply(this,arguments);e.apply(this,arguments).then((e=>t(null,e)),t)}),"name",{value:e.name})}};!function(e){const t=yo.fromCallback,n=we,r=["access","appendFile","chmod","chown","close","copyFile","fchmod","fchown","fdatasync","fstat","fsync","ftruncate","futimes","lchown","lchmod","link","lstat","mkdir","mkdtemp","open","readFile","readdir","readlink","realpath","rename","rmdir","stat","symlink","truncate","unlink","utimes","writeFile"].filter((e=>"function"==typeof n[e]));Object.keys(n).forEach((t=>{"promises"!==t&&(e[t]=n[t])})),r.forEach((r=>{e[r]=t(n[r])})),e.exists=function(e,t){return"function"==typeof t?n.exists(e,t):new Promise((t=>n.exists(e,t)))},e.read=function(e,t,r,u,o,i){return"function"==typeof i?n.read(e,t,r,u,o,i):new Promise(((i,s)=>{n.read(e,t,r,u,o,((e,t,n)=>{if(e)return s(e);i({bytesRead:t,buffer:n})}))}))},e.write=function(e,t,...r){return"function"==typeof r[r.length-1]?n.write(e,t,...r):new Promise(((u,o)=>{n.write(e,t,...r,((e,t,n)=>{if(e)return o(e);u({bytesWritten:t,buffer:n})}))}))},"function"==typeof n.realpath.native&&(e.realpath.native=t(n.realpath.native))}(ho);const Co=p.default;function Fo(e){return(e=Co.normalize(Co.resolve(e)).split(Co.sep)).length>0?e[0]:null}const go=/[<>:"|?*]/;var Ao=function(e){const t=Fo(e);return e=e.replace(t,""),go.test(e)};const vo=we,So=p.default,wo=Ao,Oo=parseInt("0777",8);var bo=function e(t,n,r,u){if("function"==typeof n?(r=n,n={}):n&&"object"==typeof n||(n={mode:n}),"win32"===process.platform&&wo(t)){const e=new Error(t+" contains invalid WIN32 path characters.");return e.code="EINVAL",r(e)}let o=n.mode;const i=n.fs||vo;void 0===o&&(o=Oo&~process.umask()),u||(u=null),r=r||function(){},t=So.resolve(t),i.mkdir(t,o,(o=>{if(!o)return r(null,u=u||t);if("ENOENT"===o.code){if(So.dirname(t)===t)return r(o);e(So.dirname(t),n,((u,o)=>{u?r(u,o):e(t,n,r,o)}))}else i.stat(t,((e,t)=>{e||!t.isDirectory()?r(o,u):r(null,u)}))}))};const _o=we,Bo=p.default,Po=Ao,ko=parseInt("0777",8);var xo=function e(t,n,r){n&&"object"==typeof n||(n={mode:n});let u=n.mode;const o=n.fs||_o;if("win32"===process.platform&&Po(t)){const e=new Error(t+" contains invalid WIN32 path characters.");throw e.code="EINVAL",e}void 0===u&&(u=ko&~process.umask()),r||(r=null),t=Bo.resolve(t);try{o.mkdirSync(t,u),r=r||t}catch(u){if("ENOENT"===u.code){if(Bo.dirname(t)===t)throw u;r=e(Bo.dirname(t),n,r),e(t,n,r)}else{let e;try{e=o.statSync(t)}catch(e){throw u}if(!e.isDirectory())throw u}}return r};const No=(0,yo.fromCallback)(bo);var Io={mkdirs:No,mkdirsSync:xo,mkdirp:No,mkdirpSync:xo,ensureDir:No,ensureDirSync:xo};const To=we;E.default,p.default;var Ro=function(e,t,n,r){To.open(e,"r+",((e,u)=>{if(e)return r(e);To.futimes(u,t,n,(e=>{To.close(u,(t=>{r&&r(e||t)}))}))}))},Mo=function(e,t,n){const r=To.openSync(e,"r+");return To.futimesSync(r,t,n),To.closeSync(r)};const Lo=we,jo=p.default,$o=10,Ho=5,Jo=0,Go=process.versions.node.split("."),Vo=Number.parseInt(Go[0],10),Uo=Number.parseInt(Go[1],10),Wo=Number.parseInt(Go[2],10);function zo(){if(Vo>$o)return!0;if(Vo===$o){if(Uo>Ho)return!0;if(Uo===Ho&&Wo>=Jo)return!0}return!1}function Ko(e,t){const n=jo.resolve(e).split(jo.sep).filter((e=>e)),r=jo.resolve(t).split(jo.sep).filter((e=>e));return n.reduce(((e,t,n)=>e&&r[n]===t),!0)}function qo(e,t,n){return`Cannot ${n} '${e}' to a subdirectory of itself, '${t}'.`}var Yo,Xo,Zo={checkPaths:function(e,t,n,r){!function(e,t,n){zo()?Lo.stat(e,{bigint:!0},((e,r)=>{if(e)return n(e);Lo.stat(t,{bigint:!0},((e,t)=>e?"ENOENT"===e.code?n(null,{srcStat:r,destStat:null}):n(e):n(null,{srcStat:r,destStat:t})))})):Lo.stat(e,((e,r)=>{if(e)return n(e);Lo.stat(t,((e,t)=>e?"ENOENT"===e.code?n(null,{srcStat:r,destStat:null}):n(e):n(null,{srcStat:r,destStat:t})))}))}(e,t,((u,o)=>{if(u)return r(u);const{srcStat:i,destStat:s}=o;return s&&s.ino&&s.dev&&s.ino===i.ino&&s.dev===i.dev?r(new Error("Source and destination must not be the same.")):i.isDirectory()&&Ko(e,t)?r(new Error(qo(e,t,n))):r(null,{srcStat:i,destStat:s})}))},checkPathsSync:function(e,t,n){const{srcStat:r,destStat:u}=function(e,t){let n,r;n=zo()?Lo.statSync(e,{bigint:!0}):Lo.statSync(e);try{r=zo()?Lo.statSync(t,{bigint:!0}):Lo.statSync(t)}catch(e){if("ENOENT"===e.code)return{srcStat:n,destStat:null};throw e}return{srcStat:n,destStat:r}}(e,t);if(u&&u.ino&&u.dev&&u.ino===r.ino&&u.dev===r.dev)throw new Error("Source and destination must not be the same.");if(r.isDirectory()&&Ko(e,t))throw new Error(qo(e,t,n));return{srcStat:r,destStat:u}},checkParentPaths:function e(t,n,r,u,o){const i=jo.resolve(jo.dirname(t)),s=jo.resolve(jo.dirname(r));if(s===i||s===jo.parse(s).root)return o();zo()?Lo.stat(s,{bigint:!0},((i,c)=>i?"ENOENT"===i.code?o():o(i):c.ino&&c.dev&&c.ino===n.ino&&c.dev===n.dev?o(new Error(qo(t,r,u))):e(t,n,s,u,o))):Lo.stat(s,((i,c)=>i?"ENOENT"===i.code?o():o(i):c.ino&&c.dev&&c.ino===n.ino&&c.dev===n.dev?o(new Error(qo(t,r,u))):e(t,n,s,u,o)))},checkParentPathsSync:function e(t,n,r,u){const o=jo.resolve(jo.dirname(t)),i=jo.resolve(jo.dirname(r));if(i===o||i===jo.parse(i).root)return;let s;try{s=zo()?Lo.statSync(i,{bigint:!0}):Lo.statSync(i)}catch(e){if("ENOENT"===e.code)return;throw e}if(s.ino&&s.dev&&s.ino===n.ino&&s.dev===n.dev)throw new Error(qo(t,r,u));return e(t,n,i,u)},isSrcSubdir:Ko};const Qo=we,ei=p.default,ti=Io.mkdirsSync,ni=Mo,ri=Zo;function ui(e,t,n,r){if(!r.filter||r.filter(t,n))return function(e,t,n,r){const u=r.dereference?Qo.statSync:Qo.lstatSync,o=u(t);if(o.isDirectory())return function(e,t,n,r,u){if(!t)return function(e,t,n,r){return Qo.mkdirSync(n),ii(t,n,r),Qo.chmodSync(n,e.mode)}(e,n,r,u);if(t&&!t.isDirectory())throw new Error(`Cannot overwrite non-directory '${r}' with directory '${n}'.`);return ii(n,r,u)}(o,e,t,n,r);if(o.isFile()||o.isCharacterDevice()||o.isBlockDevice())return function(e,t,n,r,u){return t?function(e,t,n,r){if(r.overwrite)return Qo.unlinkSync(n),oi(e,t,n,r);if(r.errorOnExist)throw new Error(`'${n}' already exists`)}(e,n,r,u):oi(e,n,r,u)}(o,e,t,n,r);if(o.isSymbolicLink())return function(e,t,n,r){let u=Qo.readlinkSync(t);r.dereference&&(u=ei.resolve(process.cwd(),u));if(e){let e;try{e=Qo.readlinkSync(n)}catch(e){if("EINVAL"===e.code||"UNKNOWN"===e.code)return Qo.symlinkSync(u,n);throw e}if(r.dereference&&(e=ei.resolve(process.cwd(),e)),ri.isSrcSubdir(u,e))throw new Error(`Cannot copy '${u}' to a subdirectory of itself, '${e}'.`);if(Qo.statSync(n).isDirectory()&&ri.isSrcSubdir(e,u))throw new Error(`Cannot overwrite '${e}' with '${u}'.`);return function(e,t){return Qo.unlinkSync(t),Qo.symlinkSync(e,t)}(u,n)}return Qo.symlinkSync(u,n)}(e,t,n,r)}(e,t,n,r)}function oi(e,t,n,r){return"function"==typeof Qo.copyFileSync?(Qo.copyFileSync(t,n),Qo.chmodSync(n,e.mode),r.preserveTimestamps?ni(n,e.atime,e.mtime):void 0):function(e,t,n,r){const u=65536,o=(Xo?Yo:(Xo=1,Yo=function(e){if("function"==typeof Buffer.allocUnsafe)try{return Buffer.allocUnsafe(e)}catch(t){return new Buffer(e)}return new Buffer(e)}))(u),i=Qo.openSync(t,"r"),s=Qo.openSync(n,"w",e.mode);let c=0;for(;cfunction(e,t,n,r){const u=ei.join(t,e),o=ei.join(n,e),{destStat:i}=ri.checkPathsSync(u,o,"copy");return ui(i,u,o,r)}(r,e,t,n)))}var si=function(e,t,n){"function"==typeof n&&(n={filter:n}),(n=n||{}).clobber=!("clobber"in n)||!!n.clobber,n.overwrite="overwrite"in n?!!n.overwrite:n.clobber,n.preserveTimestamps&&"ia32"===process.arch&&console.warn("fs-extra: Using the preserveTimestamps option in 32-bit node is not recommended;\n\n see https://github.com/jprichardson/node-fs-extra/issues/269");const{srcStat:r,destStat:u}=ri.checkPathsSync(e,t,"copy");return ri.checkParentPathsSync(e,r,t,"copy"),function(e,t,n,r){if(r.filter&&!r.filter(t,n))return;const u=ei.dirname(n);Qo.existsSync(u)||ti(u);return ui(e,t,n,r)}(u,e,t,n)},ci={copySync:si};const ai=yo.fromPromise,li=ho;var fi={pathExists:ai((function(e){return li.access(e).then((()=>!0)).catch((()=>!1))})),pathExistsSync:li.existsSync};const di=we,Di=p.default,pi=Io.mkdirs,Ei=fi.pathExists,mi=Ro,hi=Zo;function yi(e,t,n,r,u){const o=Di.dirname(n);Ei(o,((i,s)=>i?u(i):s?Fi(e,t,n,r,u):void pi(o,(o=>o?u(o):Fi(e,t,n,r,u)))))}function Ci(e,t,n,r,u,o){Promise.resolve(u.filter(n,r)).then((i=>i?e(t,n,r,u,o):o()),(e=>o(e)))}function Fi(e,t,n,r,u){return r.filter?Ci(gi,e,t,n,r,u):gi(e,t,n,r,u)}function gi(e,t,n,r,u){(r.dereference?di.stat:di.lstat)(t,((o,i)=>o?u(o):i.isDirectory()?function(e,t,n,r,u,o){if(!t)return function(e,t,n,r,u){di.mkdir(n,(o=>{if(o)return u(o);Si(t,n,r,(t=>t?u(t):di.chmod(n,e.mode,u)))}))}(e,n,r,u,o);if(t&&!t.isDirectory())return o(new Error(`Cannot overwrite non-directory '${r}' with directory '${n}'.`));return Si(n,r,u,o)}(i,e,t,n,r,u):i.isFile()||i.isCharacterDevice()||i.isBlockDevice()?function(e,t,n,r,u,o){return t?function(e,t,n,r,u){if(!r.overwrite)return r.errorOnExist?u(new Error(`'${n}' already exists`)):u();di.unlink(n,(o=>o?u(o):Ai(e,t,n,r,u)))}(e,n,r,u,o):Ai(e,n,r,u,o)}(i,e,t,n,r,u):i.isSymbolicLink()?function(e,t,n,r,u){di.readlink(t,((t,o)=>t?u(t):(r.dereference&&(o=Di.resolve(process.cwd(),o)),e?void di.readlink(n,((t,i)=>t?"EINVAL"===t.code||"UNKNOWN"===t.code?di.symlink(o,n,u):u(t):(r.dereference&&(i=Di.resolve(process.cwd(),i)),hi.isSrcSubdir(o,i)?u(new Error(`Cannot copy '${o}' to a subdirectory of itself, '${i}'.`)):e.isDirectory()&&hi.isSrcSubdir(i,o)?u(new Error(`Cannot overwrite '${i}' with '${o}'.`)):function(e,t,n){di.unlink(t,(r=>r?n(r):di.symlink(e,t,n)))}(o,n,u)))):di.symlink(o,n,u))))}(e,t,n,r,u):void 0))}function Ai(e,t,n,r,u){return"function"==typeof di.copyFile?di.copyFile(t,n,(t=>t?u(t):vi(e,n,r,u))):function(e,t,n,r,u){const o=di.createReadStream(t);o.on("error",(e=>u(e))).once("open",(()=>{const t=di.createWriteStream(n,{mode:e.mode});t.on("error",(e=>u(e))).on("open",(()=>o.pipe(t))).once("close",(()=>vi(e,n,r,u)))}))}(e,t,n,r,u)}function vi(e,t,n,r){di.chmod(t,e.mode,(u=>u?r(u):n.preserveTimestamps?mi(t,e.atime,e.mtime,r):r()))}function Si(e,t,n,r){di.readdir(e,((u,o)=>u?r(u):wi(o,e,t,n,r)))}function wi(e,t,n,r,u){const o=e.pop();return o?function(e,t,n,r,u,o){const i=Di.join(n,t),s=Di.join(r,t);hi.checkPaths(i,s,"copy",((t,c)=>{if(t)return o(t);const{destStat:a}=c;Fi(a,i,s,u,(t=>t?o(t):wi(e,n,r,u,o)))}))}(e,o,t,n,r,u):u()}var Oi=function(e,t,n,r){"function"!=typeof n||r?"function"==typeof n&&(n={filter:n}):(r=n,n={}),r=r||function(){},(n=n||{}).clobber=!("clobber"in n)||!!n.clobber,n.overwrite="overwrite"in n?!!n.overwrite:n.clobber,n.preserveTimestamps&&"ia32"===process.arch&&console.warn("fs-extra: Using the preserveTimestamps option in 32-bit node is not recommended;\n\n see https://github.com/jprichardson/node-fs-extra/issues/269"),hi.checkPaths(e,t,"copy",((u,o)=>{if(u)return r(u);const{srcStat:i,destStat:s}=o;hi.checkParentPaths(e,i,t,"copy",(u=>u?r(u):n.filter?Ci(yi,s,e,t,n,r):yi(s,e,t,n,r)))}))};var bi={copy:(0,yo.fromCallback)(Oi)};const _i=we,Bi=p.default,Pi=g.default,ki="win32"===process.platform;function xi(e){["unlink","chmod","stat","lstat","rmdir","readdir"].forEach((t=>{e[t]=e[t]||_i[t],e[t+="Sync"]=e[t]||_i[t]})),e.maxBusyTries=e.maxBusyTries||3}function Ni(e,t,n){let r=0;"function"==typeof t&&(n=t,t={}),Pi(e,"rimraf: missing path"),Pi.strictEqual(typeof e,"string","rimraf: path should be a string"),Pi.strictEqual(typeof n,"function","rimraf: callback function required"),Pi(t,"rimraf: invalid options argument provided"),Pi.strictEqual(typeof t,"object","rimraf: options should be object"),xi(t),Ii(e,t,(function u(o){if(o){if(("EBUSY"===o.code||"ENOTEMPTY"===o.code||"EPERM"===o.code)&&rIi(e,t,u)),100*r)}"ENOENT"===o.code&&(o=null)}n(o)}))}function Ii(e,t,n){Pi(e),Pi(t),Pi("function"==typeof n),t.lstat(e,((r,u)=>r&&"ENOENT"===r.code?n(null):r&&"EPERM"===r.code&&ki?Ti(e,t,r,n):u&&u.isDirectory()?Mi(e,t,r,n):void t.unlink(e,(r=>{if(r){if("ENOENT"===r.code)return n(null);if("EPERM"===r.code)return ki?Ti(e,t,r,n):Mi(e,t,r,n);if("EISDIR"===r.code)return Mi(e,t,r,n)}return n(r)}))))}function Ti(e,t,n,r){Pi(e),Pi(t),Pi("function"==typeof r),n&&Pi(n instanceof Error),t.chmod(e,438,(u=>{u?r("ENOENT"===u.code?null:n):t.stat(e,((u,o)=>{u?r("ENOENT"===u.code?null:n):o.isDirectory()?Mi(e,t,n,r):t.unlink(e,r)}))}))}function Ri(e,t,n){let r;Pi(e),Pi(t),n&&Pi(n instanceof Error);try{t.chmodSync(e,438)}catch(e){if("ENOENT"===e.code)return;throw n}try{r=t.statSync(e)}catch(e){if("ENOENT"===e.code)return;throw n}r.isDirectory()?ji(e,t,n):t.unlinkSync(e)}function Mi(e,t,n,r){Pi(e),Pi(t),n&&Pi(n instanceof Error),Pi("function"==typeof r),t.rmdir(e,(u=>{!u||"ENOTEMPTY"!==u.code&&"EEXIST"!==u.code&&"EPERM"!==u.code?u&&"ENOTDIR"===u.code?r(n):r(u):function(e,t,n){Pi(e),Pi(t),Pi("function"==typeof n),t.readdir(e,((r,u)=>{if(r)return n(r);let o,i=u.length;if(0===i)return t.rmdir(e,n);u.forEach((r=>{Ni(Bi.join(e,r),t,(r=>{if(!o)return r?n(o=r):void(0==--i&&t.rmdir(e,n))}))}))}))}(e,t,r)}))}function Li(e,t){let n;xi(t=t||{}),Pi(e,"rimraf: missing path"),Pi.strictEqual(typeof e,"string","rimraf: path should be a string"),Pi(t,"rimraf: missing options"),Pi.strictEqual(typeof t,"object","rimraf: options should be object");try{n=t.lstatSync(e)}catch(n){if("ENOENT"===n.code)return;"EPERM"===n.code&&ki&&Ri(e,t,n)}try{n&&n.isDirectory()?ji(e,t,null):t.unlinkSync(e)}catch(n){if("ENOENT"===n.code)return;if("EPERM"===n.code)return ki?Ri(e,t,n):ji(e,t,n);if("EISDIR"!==n.code)throw n;ji(e,t,n)}}function ji(e,t,n){Pi(e),Pi(t),n&&Pi(n instanceof Error);try{t.rmdirSync(e)}catch(r){if("ENOTDIR"===r.code)throw n;if("ENOTEMPTY"===r.code||"EEXIST"===r.code||"EPERM"===r.code)!function(e,t){if(Pi(e),Pi(t),t.readdirSync(e).forEach((n=>Li(Bi.join(e,n),t))),!ki){return t.rmdirSync(e,t)}{const n=Date.now();do{try{return t.rmdirSync(e,t)}catch(e){}}while(Date.now()-n<500)}}(e,t);else if("ENOENT"!==r.code)throw r}}var $i=Ni;Ni.sync=Li;const Hi=$i;var Ji={remove:(0,yo.fromCallback)(Hi),removeSync:Hi.sync};const Gi=yo.fromCallback,Vi=we,Ui=p.default,Wi=Io,zi=Ji,Ki=Gi((function(e,t){t=t||function(){},Vi.readdir(e,((n,r)=>{if(n)return Wi.mkdirs(e,t);r=r.map((t=>Ui.join(e,t))),function e(){const n=r.pop();if(!n)return t();zi.remove(n,(n=>{if(n)return t(n);e()}))}()}))}));function qi(e){let t;try{t=Vi.readdirSync(e)}catch(t){return Wi.mkdirsSync(e)}t.forEach((t=>{t=Ui.join(e,t),zi.removeSync(t)}))}var Yi={emptyDirSync:qi,emptydirSync:qi,emptyDir:Ki,emptydir:Ki};const Xi=yo.fromCallback,Zi=p.default,Qi=we,es=Io,ts=fi.pathExists;var ns={createFile:Xi((function(e,t){function n(){Qi.writeFile(e,"",(e=>{if(e)return t(e);t()}))}Qi.stat(e,((r,u)=>{if(!r&&u.isFile())return t();const o=Zi.dirname(e);ts(o,((e,r)=>e?t(e):r?n():void es.mkdirs(o,(e=>{if(e)return t(e);n()}))))}))})),createFileSync:function(e){let t;try{t=Qi.statSync(e)}catch(e){}if(t&&t.isFile())return;const n=Zi.dirname(e);Qi.existsSync(n)||es.mkdirsSync(n),Qi.writeFileSync(e,"")}};const rs=yo.fromCallback,us=p.default,os=we,is=Io,ss=fi.pathExists;var cs={createLink:rs((function(e,t,n){function r(e,t){os.link(e,t,(e=>{if(e)return n(e);n(null)}))}ss(t,((u,o)=>u?n(u):o?n(null):void os.lstat(e,(u=>{if(u)return u.message=u.message.replace("lstat","ensureLink"),n(u);const o=us.dirname(t);ss(o,((u,i)=>u?n(u):i?r(e,t):void is.mkdirs(o,(u=>{if(u)return n(u);r(e,t)}))))}))))})),createLinkSync:function(e,t){if(os.existsSync(t))return;try{os.lstatSync(e)}catch(e){throw e.message=e.message.replace("lstat","ensureLink"),e}const n=us.dirname(t);return os.existsSync(n)||is.mkdirsSync(n),os.linkSync(e,t)}};const as=p.default,ls=we,fs=fi.pathExists;var ds={symlinkPaths:function(e,t,n){if(as.isAbsolute(e))return ls.lstat(e,(t=>t?(t.message=t.message.replace("lstat","ensureSymlink"),n(t)):n(null,{toCwd:e,toDst:e})));{const r=as.dirname(t),u=as.join(r,e);return fs(u,((t,o)=>t?n(t):o?n(null,{toCwd:u,toDst:e}):ls.lstat(e,(t=>t?(t.message=t.message.replace("lstat","ensureSymlink"),n(t)):n(null,{toCwd:e,toDst:as.relative(r,e)})))))}},symlinkPathsSync:function(e,t){let n;if(as.isAbsolute(e)){if(n=ls.existsSync(e),!n)throw new Error("absolute srcpath does not exist");return{toCwd:e,toDst:e}}{const r=as.dirname(t),u=as.join(r,e);if(n=ls.existsSync(u),n)return{toCwd:u,toDst:e};if(n=ls.existsSync(e),!n)throw new Error("relative srcpath does not exist");return{toCwd:e,toDst:as.relative(r,e)}}}};const Ds=we;var ps={symlinkType:function(e,t,n){if(n="function"==typeof t?t:n,t="function"!=typeof t&&t)return n(null,t);Ds.lstat(e,((e,r)=>{if(e)return n(null,"file");t=r&&r.isDirectory()?"dir":"file",n(null,t)}))},symlinkTypeSync:function(e,t){let n;if(t)return t;try{n=Ds.lstatSync(e)}catch(e){return"file"}return n&&n.isDirectory()?"dir":"file"}};const Es=yo.fromCallback,ms=p.default,hs=we,ys=Io.mkdirs,Cs=Io.mkdirsSync,Fs=ds.symlinkPaths,gs=ds.symlinkPathsSync,As=ps.symlinkType,vs=ps.symlinkTypeSync,Ss=fi.pathExists;var ws={createSymlink:Es((function(e,t,n,r){r="function"==typeof n?n:r,n="function"!=typeof n&&n,Ss(t,((u,o)=>u?r(u):o?r(null):void Fs(e,t,((u,o)=>{if(u)return r(u);e=o.toDst,As(o.toCwd,n,((n,u)=>{if(n)return r(n);const o=ms.dirname(t);Ss(o,((n,i)=>n?r(n):i?hs.symlink(e,t,u,r):void ys(o,(n=>{if(n)return r(n);hs.symlink(e,t,u,r)}))))}))}))))})),createSymlinkSync:function(e,t,n){if(hs.existsSync(t))return;const r=gs(e,t);e=r.toDst,n=vs(r.toCwd,n);const u=ms.dirname(t);return hs.existsSync(u)||Cs(u),hs.symlinkSync(e,t,n)}};var Os,bs={createFile:ns.createFile,createFileSync:ns.createFileSync,ensureFile:ns.createFile,ensureFileSync:ns.createFileSync,createLink:cs.createLink,createLinkSync:cs.createLinkSync,ensureLink:cs.createLink,ensureLinkSync:cs.createLinkSync,createSymlink:ws.createSymlink,createSymlinkSync:ws.createSymlinkSync,ensureSymlink:ws.createSymlink,ensureSymlinkSync:ws.createSymlinkSync};try{Os=we}catch(e){Os=D.default}function _s(e,t){var n,r="\n";return"object"==typeof t&&null!==t&&(t.spaces&&(n=t.spaces),t.EOL&&(r=t.EOL)),JSON.stringify(e,t?t.replacer:null,n).replace(/\n/g,r)+r}function Bs(e){return Buffer.isBuffer(e)&&(e=e.toString("utf8")),e=e.replace(/^\uFEFF/,"")}var Ps={readFile:function(e,t,n){null==n&&(n=t,t={}),"string"==typeof t&&(t={encoding:t});var r=(t=t||{}).fs||Os,u=!0;"throws"in t&&(u=t.throws),r.readFile(e,t,(function(r,o){if(r)return n(r);var i;o=Bs(o);try{i=JSON.parse(o,t?t.reviver:null)}catch(t){return u?(t.message=e+": "+t.message,n(t)):n(null,null)}n(null,i)}))},readFileSync:function(e,t){"string"==typeof(t=t||{})&&(t={encoding:t});var n=t.fs||Os,r=!0;"throws"in t&&(r=t.throws);try{var u=n.readFileSync(e,t);return u=Bs(u),JSON.parse(u,t.reviver)}catch(t){if(r)throw t.message=e+": "+t.message,t;return null}},writeFile:function(e,t,n,r){null==r&&(r=n,n={});var u=(n=n||{}).fs||Os,o="";try{o=_s(t,n)}catch(e){return void(r&&r(e,null))}u.writeFile(e,o,n,r)},writeFileSync:function(e,t,n){var r=(n=n||{}).fs||Os,u=_s(t,n);return r.writeFileSync(e,u,n)}},ks=Ps;const xs=yo.fromCallback,Ns=ks;var Is={readJson:xs(Ns.readFile),readJsonSync:Ns.readFileSync,writeJson:xs(Ns.writeFile),writeJsonSync:Ns.writeFileSync};const Ts=p.default,Rs=Io,Ms=fi.pathExists,Ls=Is;var js=function(e,t,n,r){"function"==typeof n&&(r=n,n={});const u=Ts.dirname(e);Ms(u,((o,i)=>o?r(o):i?Ls.writeJson(e,t,n,r):void Rs.mkdirs(u,(u=>{if(u)return r(u);Ls.writeJson(e,t,n,r)}))))};const $s=we,Hs=p.default,Js=Io,Gs=Is;var Vs=function(e,t,n){const r=Hs.dirname(e);$s.existsSync(r)||Js.mkdirsSync(r),Gs.writeJsonSync(e,t,n)};const Us=yo.fromCallback,Ws=Is;Ws.outputJson=Us(js),Ws.outputJsonSync=Vs,Ws.outputJSON=Ws.outputJson,Ws.outputJSONSync=Ws.outputJsonSync,Ws.writeJSON=Ws.writeJson,Ws.writeJSONSync=Ws.writeJsonSync,Ws.readJSON=Ws.readJson,Ws.readJSONSync=Ws.readJsonSync;var zs=Ws;const Ks=we,qs=p.default,Ys=ci.copySync,Xs=Ji.removeSync,Zs=Io.mkdirpSync,Qs=Zo;function ec(e,t,n){try{Ks.renameSync(e,t)}catch(r){if("EXDEV"!==r.code)throw r;return function(e,t,n){const r={overwrite:n,errorOnExist:!0};return Ys(e,t,r),Xs(e)}(e,t,n)}}var tc=function(e,t,n){const r=(n=n||{}).overwrite||n.clobber||!1,{srcStat:u}=Qs.checkPathsSync(e,t,"move");return Qs.checkParentPathsSync(e,u,t,"move"),Zs(qs.dirname(t)),function(e,t,n){if(n)return Xs(t),ec(e,t,n);if(Ks.existsSync(t))throw new Error("dest already exists.");return ec(e,t,n)}(e,t,r)},nc={moveSync:tc};const rc=we,uc=p.default,oc=bi.copy,ic=Ji.remove,sc=Io.mkdirp,cc=fi.pathExists,ac=Zo;function lc(e,t,n,r){rc.rename(e,t,(u=>u?"EXDEV"!==u.code?r(u):function(e,t,n,r){const u={overwrite:n,errorOnExist:!0};oc(e,t,u,(t=>t?r(t):ic(e,r)))}(e,t,n,r):r()))}var fc=function(e,t,n,r){"function"==typeof n&&(r=n,n={});const u=n.overwrite||n.clobber||!1;ac.checkPaths(e,t,"move",((n,o)=>{if(n)return r(n);const{srcStat:i}=o;ac.checkParentPaths(e,i,t,"move",(n=>{if(n)return r(n);sc(uc.dirname(t),(n=>n?r(n):function(e,t,n,r){if(n)return ic(t,(u=>u?r(u):lc(e,t,n,r)));cc(t,((u,o)=>u?r(u):o?r(new Error("dest already exists.")):lc(e,t,n,r)))}(e,t,u,r)))}))}))};var dc={move:(0,yo.fromCallback)(fc)};const Dc=yo.fromCallback,pc=we,Ec=p.default,mc=Io,hc=fi.pathExists;var yc={outputFile:Dc((function(e,t,n,r){"function"==typeof n&&(r=n,n="utf8");const u=Ec.dirname(e);hc(u,((o,i)=>o?r(o):i?pc.writeFile(e,t,n,r):void mc.mkdirs(u,(u=>{if(u)return r(u);pc.writeFile(e,t,n,r)}))))})),outputFileSync:function(e,...t){const n=Ec.dirname(e);if(pc.existsSync(n))return pc.writeFileSync(e,...t);mc.mkdirsSync(n),pc.writeFileSync(e,...t)}};!function(e){e.exports=Object.assign({},ho,ci,bi,Yi,bs,zs,Io,nc,dc,yc,fi,Ji);const t=D.default;Object.getOwnPropertyDescriptor(t,"promises")&&Object.defineProperty(e.exports,"promises",{get:()=>t.promises})}(mo);const Cc=Nr.exports("streamroller:fileNameFormatter"),Fc=p.default;const gc=Nr.exports("streamroller:fileNameParser"),Ac=nu.exports;const vc=Nr.exports("streamroller:moveAndMaybeCompressFile"),Sc=mo.exports,wc=v.default;var Oc=async(e,t,n)=>{if(n=function(e){const t={mode:parseInt("0600",8),compress:!1},n=Object.assign({},t,e);return vc(`_parseOption: moveAndMaybeCompressFile called with option=${JSON.stringify(n)}`),n}(n),e!==t){if(await Sc.pathExists(e))if(vc(`moveAndMaybeCompressFile: moving file from ${e} to ${t} ${n.compress?"with":"without"} compress`),n.compress)await new Promise(((r,u)=>{let o=!1;const i=Sc.createWriteStream(t,{mode:n.mode,flags:"wx"}).on("open",(()=>{o=!0;const t=Sc.createReadStream(e).on("open",(()=>{t.pipe(wc.createGzip()).pipe(i)})).on("error",(t=>{vc(`moveAndMaybeCompressFile: error reading ${e}`,t),i.destroy(t)}))})).on("finish",(()=>{vc(`moveAndMaybeCompressFile: finished compressing ${t}, deleting ${e}`),Sc.unlink(e).then(r).catch((t=>{vc(`moveAndMaybeCompressFile: error deleting ${e}, truncating instead`,t),Sc.truncate(e).then(r).catch((t=>{vc(`moveAndMaybeCompressFile: error truncating ${e}`,t),u(t)}))}))})).on("error",(e=>{o?(vc(`moveAndMaybeCompressFile: error writing ${t}, deleting`,e),Sc.unlink(t).then((()=>{u(e)})).catch((e=>{vc(`moveAndMaybeCompressFile: error deleting ${t}`,e),u(e)}))):(vc(`moveAndMaybeCompressFile: error creating ${t}`,e),u(e))}))})).catch((()=>{}));else{vc(`moveAndMaybeCompressFile: renaming ${e} to ${t}`);try{await Sc.move(e,t,{overwrite:!0})}catch(n){if(vc(`moveAndMaybeCompressFile: error renaming ${e} to ${t}`,n),"ENOENT"!==n.code){vc("moveAndMaybeCompressFile: trying copy+truncate instead");try{await Sc.copy(e,t,{overwrite:!0}),await Sc.truncate(e)}catch(e){vc("moveAndMaybeCompressFile: error copy+truncate",e)}}}}}else vc("moveAndMaybeCompressFile: source and target are the same, not doing anything")};const bc=Nr.exports("streamroller:RollingFileWriteStream"),_c=mo.exports,Bc=p.default,Pc=E.default,kc=()=>new Date,xc=nu.exports,{Writable:Nc}=C.default,Ic=({file:e,keepFileExt:t,needsIndex:n,alwaysIncludeDate:r,compress:u,fileNameSep:o})=>{let i=o||".";const s=Fc.join(e.dir,e.name),c=t=>t+e.ext,a=(e,t,r)=>!n&&r||!t?e:e+i+t,l=(e,t,n)=>(t>0||r)&&n?e+i+n:e,f=(e,t)=>t&&u?e+".gz":e,d=t?[l,a,c,f]:[c,l,a,f];return({date:e,index:t})=>(Cc(`_formatFileName: date=${e}, index=${t}`),d.reduce(((n,r)=>r(n,t,e)),s))},Tc=({file:e,keepFileExt:t,pattern:n,fileNameSep:r})=>{let u=r||".";const o="__NOT_MATCHING__";let i=[(e,t)=>e.endsWith(".gz")?(gc("it is gzipped"),t.isCompressed=!0,e.slice(0,-1*".gz".length)):e,t?t=>t.startsWith(e.name)&&t.endsWith(e.ext)?(gc("it starts and ends with the right things"),t.slice(e.name.length+1,-1*e.ext.length)):o:t=>t.startsWith(e.base)?(gc("it starts with the right things"),t.slice(e.base.length+1)):o,n?(e,t)=>{const r=e.split(u);let o=r[r.length-1];gc("items: ",r,", indexStr: ",o);let i=e;void 0!==o&&o.match(/^\d+$/)?(i=e.slice(0,-1*(o.length+1)),gc(`dateStr is ${i}`),n&&!i&&(i=o,o="0")):o="0";try{const r=Ac.parse(n,i,new Date(0,0));return Ac.asString(n,r)!==i?e:(t.index=parseInt(o,10),t.date=i,t.timestamp=r.getTime(),"")}catch(t){return gc(`Problem parsing ${i} as ${n}, error was: `,t),e}}:(e,t)=>e.match(/^\d+$/)?(gc("it has an index"),t.index=parseInt(e,10),""):e];return e=>{let t={filename:e,index:0,isCompressed:!1};return i.reduce(((e,n)=>n(e,t)),e)?null:t}},Rc=Oc;var Mc=class extends Nc{constructor(e,t){if(bc(`constructor: creating RollingFileWriteStream. path=${e}`),"string"!=typeof e||0===e.length)throw new Error(`Invalid filename: ${e}`);if(e.endsWith(Bc.sep))throw new Error(`Filename is a directory: ${e}`);0===e.indexOf(`~${Bc.sep}`)&&(e=e.replace("~",Pc.homedir())),super(t),this.options=this._parseOption(t),this.fileObject=Bc.parse(e),""===this.fileObject.dir&&(this.fileObject=Bc.parse(Bc.join(process.cwd(),e))),this.fileFormatter=Ic({file:this.fileObject,alwaysIncludeDate:this.options.alwaysIncludePattern,needsIndex:this.options.maxSize 0`)}else delete n.maxSize;if(n.numBackups||0===n.numBackups){if(n.numBackups<0)throw new Error(`options.numBackups (${n.numBackups}) should be >= 0`);if(n.numBackups>=Number.MAX_SAFE_INTEGER)throw new Error(`options.numBackups (${n.numBackups}) should be < Number.MAX_SAFE_INTEGER`);n.numToKeep=n.numBackups+1}else if(n.numToKeep<=0)throw new Error(`options.numToKeep (${n.numToKeep}) should be > 0`);return bc(`_parseOption: creating stream with option=${JSON.stringify(n)}`),n}_final(e){this.currentFileStream.end("",this.options.encoding,e)}_write(e,t,n){this._shouldRoll().then((()=>{bc(`_write: writing chunk. file=${this.currentFileStream.path} state=${JSON.stringify(this.state)} chunk=${e}`),this.currentFileStream.write(e,t,(t=>{this.state.currentSize+=e.length,n(t)}))}))}async _shouldRoll(){(this._dateChanged()||this._tooBig())&&(bc(`_shouldRoll: rolling because dateChanged? ${this._dateChanged()} or tooBig? ${this._tooBig()}`),await this._roll())}_dateChanged(){return this.state.currentDate&&this.state.currentDate!==xc(this.options.pattern,kc())}_tooBig(){return this.state.currentSize>=this.options.maxSize}_roll(){return bc("_roll: closing the current stream"),new Promise(((e,t)=>{this.currentFileStream.end("",this.options.encoding,(()=>{this._moveOldFiles().then(e).catch(t)}))}))}async _moveOldFiles(){const e=await this._getExistingFiles();for(let t=(this.state.currentDate?e.filter((e=>e.date===this.state.currentDate)):e).length;t>=0;t--){bc(`_moveOldFiles: i = ${t}`);const e=this.fileFormatter({date:this.state.currentDate,index:t}),n=this.fileFormatter({date:this.state.currentDate,index:t+1}),r={compress:this.options.compress&&0===t,mode:this.options.mode};await Rc(e,n,r)}this.state.currentSize=0,this.state.currentDate=this.state.currentDate?xc(this.options.pattern,kc()):null,bc(`_moveOldFiles: finished rolling files. state=${JSON.stringify(this.state)}`),this._renewWriteStream(),await new Promise(((e,t)=>{this.currentFileStream.write("","utf8",(()=>{this._clean().then(e).catch(t)}))}))}async _getExistingFiles(){const e=await _c.readdir(this.fileObject.dir).catch((()=>[]));bc(`_getExistingFiles: files=${e}`);const t=e.map((e=>this.fileNameParser(e))).filter((e=>e)),n=e=>(e.timestamp?e.timestamp:kc().getTime())-e.index;return t.sort(((e,t)=>n(e)-n(t))),t}_renewWriteStream(){const e=this.fileFormatter({date:this.state.currentDate,index:0}),t=e=>{try{return _c.mkdirSync(e,{recursive:!0})}catch(n){if("ENOENT"===n.code)return t(Bc.dirname(e)),t(e);if("EEXIST"!==n.code&&"EROFS"!==n.code)throw n;try{if(_c.statSync(e).isDirectory())return e;throw n}catch(e){throw n}}};t(this.fileObject.dir);const n={flags:this.options.flags,encoding:this.options.encoding,mode:this.options.mode};var r,u;_c.appendFileSync(e,"",(r={...n},u="flags",r["flag"]=r[u],delete r[u],r)),this.currentFileStream=_c.createWriteStream(e,n),this.currentFileStream.on("error",(e=>{this.emit("error",e)}))}async _clean(){const e=await this._getExistingFiles();if(bc(`_clean: numToKeep = ${this.options.numToKeep}, existingFiles = ${e.length}`),bc("_clean: existing files are: ",e),this._tooManyFiles(e.length)){const n=e.slice(0,e.length-this.options.numToKeep).map((e=>Bc.format({dir:this.fileObject.dir,base:e.filename})));await(t=n,bc(`deleteFiles: files to delete: ${t}`),Promise.all(t.map((e=>_c.unlink(e).catch((t=>{bc(`deleteFiles: error when unlinking ${e}, ignoring. Error was ${t}`)}))))))}var t}_tooManyFiles(e){return this.options.numToKeep>0&&e>this.options.numToKeep}};const Lc=Mc;var jc=class extends Lc{constructor(e,t,n,r){r||(r={}),t&&(r.maxSize=t),r.numBackups||0===r.numBackups||(n||0===n||(n=1),r.numBackups=n),super(e,r),this.backups=r.numBackups,this.size=this.options.maxSize}get theStream(){return this.currentFileStream}};const $c=Mc;var Hc={RollingFileWriteStream:Mc,RollingFileStream:jc,DateRollingFileStream:class extends $c{constructor(e,t,n){t&&"object"==typeof t&&(n=t,t=null),n||(n={}),t||(t="yyyy-MM-dd"),n.pattern=t,n.numBackups||0===n.numBackups?n.daysToKeep=n.numBackups:(n.daysToKeep||0===n.daysToKeep?process.emitWarning("options.daysToKeep is deprecated due to the confusion it causes when used together with file size rolling. Please use options.numBackups instead.","DeprecationWarning","streamroller-DEP0001"):n.daysToKeep=1,n.numBackups=n.daysToKeep),super(e,n),this.mode=this.options.mode}get theStream(){return this.currentFileStream}}};const Jc=Nr.exports("log4js:file"),Gc=p.default,Vc=Hc,Uc=E.default.EOL;let Wc=!1;const zc=new Set;function Kc(){zc.forEach((e=>{e.sighupHandler()}))}function qc(e,t,n,r){const u=new Vc.RollingFileStream(e,t,n,r);return u.on("error",(t=>{console.error("log4js.fileAppender - Writing to file %s, error happened ",e,t)})),u.on("drain",(()=>{process.emit("log4js:pause",!1)})),u}Eo.configure=function(e,t){let n=t.basicLayout;return e.layout&&(n=t.layout(e.layout.type,e.layout)),e.mode=e.mode||384,function(e,t,n,r,u,o){e=Gc.normalize(e),Jc("Creating file appender (",e,", ",n,", ",r=r||0===r?r:5,", ",u,", ",o,")");let i=qc(e,n,r,u);const s=function(e){if(i.writable){if(!0===u.removeColor){const t=/\x1b[[0-9;]*m/g;e.data=e.data.map((e=>"string"==typeof e?e.replace(t,""):e))}i.write(t(e,o)+Uc,"utf8")||process.emit("log4js:pause",!0)}};return s.reopen=function(){i.end((()=>{i=qc(e,n,r,u)}))},s.sighupHandler=function(){Jc("SIGHUP handler called."),s.reopen()},s.shutdown=function(e){zc.delete(s),0===zc.size&&Wc&&(process.removeListener("SIGHUP",Kc),Wc=!1),i.end("","utf-8",e)},zc.add(s),Wc||(process.on("SIGHUP",Kc),Wc=!0),s}(e.filename,n,e.maxLogSize,e.backups,e,e.timezoneOffset)};var Yc={};const Xc=Hc,Zc=E.default.EOL;function Qc(e,t,n,r,u){r.maxSize=r.maxLogSize;const o=function(e,t,n){const r=new Xc.DateRollingFileStream(e,t,n);return r.on("error",(t=>{console.error("log4js.dateFileAppender - Writing to file %s, error happened ",e,t)})),r.on("drain",(()=>{process.emit("log4js:pause",!1)})),r}(e,t,r),i=function(e){o.writable&&(o.write(n(e,u)+Zc,"utf8")||process.emit("log4js:pause",!0))};return i.shutdown=function(e){o.end("","utf-8",e)},i}Yc.configure=function(e,t){let n=t.basicLayout;return e.layout&&(n=t.layout(e.layout.type,e.layout)),e.alwaysIncludePattern||(e.alwaysIncludePattern=!1),e.mode=e.mode||384,Qc(e.filename,e.pattern,n,e,e.timezoneOffset)};var ea={};const ta=Nr.exports("log4js:fileSync"),na=p.default,ra=D.default,ua=E.default.EOL||"\n";function oa(e,t){if(ra.existsSync(e))return;const n=ra.openSync(e,t.flags,t.mode);ra.closeSync(n)}class ia{constructor(e,t,n,r){ta("In RollingFileStream"),function(){if(!e||!t||t<=0)throw new Error("You must specify a filename and file size")}(),this.filename=e,this.size=t,this.backups=n,this.options=r,this.currentSize=0,this.currentSize=function(e){let t=0;try{t=ra.statSync(e).size}catch(t){oa(e,r)}return t}(this.filename)}shouldRoll(){return ta("should roll with current size %d, and max size %d",this.currentSize,this.size),this.currentSize>=this.size}roll(e){const t=this,n=new RegExp(`^${na.basename(e)}`);function r(e){return n.test(e)}function u(t){return parseInt(t.substring(`${na.basename(e)}.`.length),10)||0}function o(e,t){return u(e)>u(t)?1:u(e) ${e}.${r+1}`),ra.renameSync(na.join(na.dirname(e),n),`${e}.${r+1}`)}}ta("Rolling, rolling, rolling"),ta("Renaming the old files"),ra.readdirSync(na.dirname(e)).filter(r).sort(o).reverse().forEach(i)}write(e,t){const n=this;ta("in write"),this.shouldRoll()&&(this.currentSize=0,this.roll(this.filename)),ta("writing the chunk to the file"),n.currentSize+=e.length,ra.appendFileSync(n.filename,e)}}ea.configure=function(e,t){let n=t.basicLayout;e.layout&&(n=t.layout(e.layout.type,e.layout));const r={flags:e.flags||"a",encoding:e.encoding||"utf8",mode:e.mode||384};return function(e,t,n,r,u,o){ta("fileSync appender created");const i=function(e,t,n){let r;var u;return t?r=new ia(e,t,n,o):(oa(u=e,o),r={write(e){ra.appendFileSync(u,e)}}),r}(e=na.normalize(e),n,r=r||0===r?r:5);return e=>{i.write(t(e,u)+ua)}}(e.filename,n,e.maxLogSize,e.backups,e.timezoneOffset,r)};var sa={};const ca=Nr.exports("log4js:tcp"),aa=S.default;sa.configure=function(e,t){ca(`configure with config = ${e}`);let n=function(e){return e.serialise()};return e.layout&&(n=t.layout(e.layout.type,e.layout)),function(e,t){let n=!1;const r=[];let u,o=3,i="__LOG4JS__";function s(e){ca("Writing log event to socket"),n=u.write(`${t(e)}${i}`,"utf8")}function c(){let e;for(ca("emptying buffer");e=r.shift();)s(e)}function a(e){n?s(e):(ca("buffering log event because it cannot write at the moment"),r.push(e))}return function t(){ca(`appender creating socket to ${e.host||"localhost"}:${e.port||5e3}`),i=`${e.endMsg||"__LOG4JS__"}`,u=aa.createConnection(e.port||5e3,e.host||"localhost"),u.on("connect",(()=>{ca("socket connected"),c(),n=!0})),u.on("drain",(()=>{ca("drain event received, emptying buffer"),n=!0,c()})),u.on("timeout",u.end.bind(u)),u.on("error",(e=>{ca("connection error",e),n=!1,c()})),u.on("close",t)}(),a.shutdown=function(e){ca("shutdown called"),r.length&&o?(ca("buffer has items, waiting 100ms to empty"),o-=1,setTimeout((()=>{a.shutdown(e)}),100)):(u.removeAllListeners("close"),u.end(e))},a}(e,n)};const la=p.default,fa=Nr.exports("log4js:appenders"),da=tu,Da=eo,pa=gu,Ea=hu,ma=to,ha=new Map;ha.set("console",oo),ha.set("stdout",so),ha.set("stderr",co),ha.set("logLevelFilter",ao),ha.set("categoryFilter",lo),ha.set("noLogFilter",Do),ha.set("file",Eo),ha.set("dateFile",Yc),ha.set("fileSync",ea),ha.set("tcp",sa);const ya=new Map,Ca=(e,t)=>{fa("Loading module from ",e);try{return require(e)}catch(n){return void da.throwExceptionIf(t,"MODULE_NOT_FOUND"!==n.code,`appender "${e}" could not be loaded (error was: ${n})`)}},Fa=new Set,ga=(e,t)=>{if(ya.has(e))return ya.get(e);if(!t.appenders[e])return!1;if(Fa.has(e))throw new Error(`Dependency loop detected for appender ${e}.`);Fa.add(e),fa(`Creating appender ${e}`);const n=Aa(e,t);return Fa.delete(e),ya.set(e,n),n},Aa=(e,t)=>{const n=t.appenders[e],r=n.type.configure?n.type:((e,t)=>ha.get(e)||Ca(`./${e}`,t)||Ca(e,t)||require.main&&Ca(la.join(la.dirname(require.main.filename),e),t)||Ca(la.join(process.cwd(),e),t))(n.type,t);return da.throwExceptionIf(t,da.not(r),`appender "${e}" is not valid (type "${n.type}" could not be found)`),r.appender&&fa(`DEPRECATION: Appender ${n.type} exports an appender function.`),r.shutdown&&fa(`DEPRECATION: Appender ${n.type} exports a shutdown function.`),fa(`${e}: clustering.isMaster ? ${Da.isMaster()}`),fa(`${e}: appenderModule is ${F.default.inspect(r)}`),Da.onlyOnMaster((()=>(fa(`calling appenderModule.configure for ${e} / ${n.type}`),r.configure(ma.modifyConfig(n),Ea,(e=>ga(e,t)),pa))),(()=>{}))},va=e=>{ya.clear(),Fa.clear();const t=[];Object.values(e.categories).forEach((e=>{t.push(...e.appenders)})),Object.keys(e.appenders).forEach((n=>{(t.includes(n)||"tcp-server"===e.appenders[n].type)&&ga(n,e)}))},Sa=()=>{va({appenders:{out:{type:"stdout"}},categories:{default:{appenders:["out"],level:"trace"}}})};Sa(),da.addListener((e=>{da.throwExceptionIf(e,da.not(da.anObject(e.appenders)),'must have a property "appenders" of type object.');const t=Object.keys(e.appenders);da.throwExceptionIf(e,da.not(t.length),"must define at least one appender."),t.forEach((t=>{da.throwExceptionIf(e,da.not(e.appenders[t].type),`appender "${t}" is not valid (must be an object with property "type")`)}))})),da.addListener(va),Au.exports=ya,Au.exports.init=Sa;var wa={exports:{}};!function(e){const t=Nr.exports("log4js:categories"),n=tu,r=gu,u=Au.exports,o=new Map;function i(e,t,n){if(!1===t.inherit)return;const r=n.lastIndexOf(".");if(r<0)return;const u=n.substring(0,r);let o=e.categories[u];o||(o={inherit:!0,appenders:[]}),i(e,o,u),!e.categories[u]&&o.appenders&&o.appenders.length&&o.level&&(e.categories[u]=o),t.appenders=t.appenders||[],t.level=t.level||o.level,o.appenders.forEach((e=>{t.appenders.includes(e)||t.appenders.push(e)})),t.parent=o}function s(e){if(!e.categories)return;Object.keys(e.categories).forEach((t=>{const n=e.categories[t];i(e,n,t)}))}n.addPreProcessingListener((e=>s(e))),n.addListener((e=>{n.throwExceptionIf(e,n.not(n.anObject(e.categories)),'must have a property "categories" of type object.');const t=Object.keys(e.categories);n.throwExceptionIf(e,n.not(t.length),"must define at least one category."),t.forEach((t=>{const o=e.categories[t];n.throwExceptionIf(e,[n.not(o.appenders),n.not(o.level)],`category "${t}" is not valid (must be an object with properties "appenders" and "level")`),n.throwExceptionIf(e,n.not(Array.isArray(o.appenders)),`category "${t}" is not valid (appenders must be an array of appender names)`),n.throwExceptionIf(e,n.not(o.appenders.length),`category "${t}" is not valid (appenders must contain at least one appender name)`),Object.prototype.hasOwnProperty.call(o,"enableCallStack")&&n.throwExceptionIf(e,"boolean"!=typeof o.enableCallStack,`category "${t}" is not valid (enableCallStack must be boolean type)`),o.appenders.forEach((r=>{n.throwExceptionIf(e,n.not(u.get(r)),`category "${t}" is not valid (appender "${r}" is not defined)`)})),n.throwExceptionIf(e,n.not(r.getLevel(o.level)),`category "${t}" is not valid (level "${o.level}" not recognised; valid levels are ${r.levels.join(", ")})`)})),n.throwExceptionIf(e,n.not(e.categories.default),'must define a "default" category.')}));const c=e=>{o.clear();Object.keys(e.categories).forEach((n=>{const i=e.categories[n],s=[];i.appenders.forEach((e=>{s.push(u.get(e)),t(`Creating category ${n}`),o.set(n,{appenders:s,level:r.getLevel(i.level),enableCallStack:i.enableCallStack||!1})}))}))},a=()=>{c({categories:{default:{appenders:["out"],level:"OFF"}}})};a(),n.addListener(c);const l=e=>(t(`configForCategory: searching for config for ${e}`),o.has(e)?(t(`configForCategory: ${e} exists in config, returning it`),o.get(e)):e.indexOf(".")>0?(t(`configForCategory: ${e} has hierarchy, searching for parents`),l(e.substring(0,e.lastIndexOf(".")))):(t("configForCategory: returning config for default category"),l("default")));e.exports=o,e.exports=Object.assign(e.exports,{appendersForCategory:e=>l(e).appenders,getLevelForCategory:e=>l(e).level,setLevelForCategory:(e,n)=>{let r=o.get(e);if(t(`setLevelForCategory: found ${r} for ${e}`),!r){const n=l(e);t(`setLevelForCategory: no config found for category, found ${n} for parents of ${e}`),r={appenders:n.appenders}}r.level=n,o.set(e,r)},getEnableCallStackForCategory:e=>!0===l(e).enableCallStack,setEnableCallStackForCategory:(e,t)=>{l(e).enableCallStack=t},init:a})}(wa);const Oa=Nr.exports("log4js:logger"),ba=Hu,_a=gu,Ba=eo,Pa=wa.exports,ka=tu,xa=/at (?:(.+)\s+\()?(?:(.+?):(\d+)(?::(\d+))?|([^)]+))\)?/;function Na(e,t=4){const n=e.stack.split("\n").slice(t),r=xa.exec(n[0]);return r&&6===r.length?{functionName:r[1],fileName:r[2],lineNumber:parseInt(r[3],10),columnNumber:parseInt(r[4],10),callStack:n.join("\n")}:null}class Ia{constructor(e){if(!e)throw new Error("No category provided.");this.category=e,this.context={},this.parseCallStack=Na,Oa(`Logger created (${this.category}, ${this.level})`)}get level(){return _a.getLevel(Pa.getLevelForCategory(this.category),_a.TRACE)}set level(e){Pa.setLevelForCategory(this.category,_a.getLevel(e,this.level))}get useCallStack(){return Pa.getEnableCallStackForCategory(this.category)}set useCallStack(e){Pa.setEnableCallStackForCategory(this.category,!0===e)}log(e,...t){let n=_a.getLevel(e);n||(this._log(_a.WARN,"log4js:logger.log: invalid value for log-level as first parameter given: ",e),n=_a.INFO),this.isLevelEnabled(n)&&this._log(n,t)}isLevelEnabled(e){return this.level.isLessThanOrEqualTo(e)}_log(e,t){Oa(`sending log data (${e}) to appenders`);const n=new ba(this.category,e,t,this.context,this.useCallStack&&this.parseCallStack(new Error));Ba.send(n)}addContext(e,t){this.context[e]=t}removeContext(e){delete this.context[e]}clearContext(){this.context={}}setParseCallStackFunction(e){this.parseCallStack=e}}function Ta(e){const t=_a.getLevel(e),n=t.toString().toLowerCase().replace(/_([a-z])/g,(e=>e[1].toUpperCase())),r=n[0].toUpperCase()+n.slice(1);Ia.prototype[`is${r}Enabled`]=function(){return this.isLevelEnabled(t)},Ia.prototype[n]=function(...e){this.log(t,...e)}}_a.levels.forEach(Ta),ka.addListener((()=>{_a.levels.forEach(Ta)}));var Ra=Ia;const Ma=gu;function La(e){return e.originalUrl||e.url}function ja(e,t){for(let n=0;ne.source?e.source:e));t=new RegExp(n.join("|"))}return t}(t.nolog);return(e,i,s)=>{if(e._logging)return s();if(o&&o.test(e.originalUrl))return s();if(n.isLevelEnabled(r)||"auto"===t.level){const o=new Date,{writeHead:s}=i;e._logging=!0,i.writeHead=(e,t)=>{i.writeHead=s,i.writeHead(e,t),i.__statusCode=e,i.__headers=t||{}},i.on("finish",(()=>{i.responseTime=new Date-o,i.statusCode&&"auto"===t.level&&(r=Ma.INFO,i.statusCode>=300&&(r=Ma.WARN),i.statusCode>=400&&(r=Ma.ERROR)),r=function(e,t,n){let r=t;if(n){const t=n.find((t=>{let n=!1;return n=t.from&&t.to?e>=t.from&&e<=t.to:-1!==t.codes.indexOf(e),n}));t&&(r=Ma.getLevel(t.level,r))}return r}(i.statusCode,r,t.statusRules);const s=function(e,t,n){const r=[];return r.push({token:":url",replacement:La(e)}),r.push({token:":protocol",replacement:e.protocol}),r.push({token:":hostname",replacement:e.hostname}),r.push({token:":method",replacement:e.method}),r.push({token:":status",replacement:t.__statusCode||t.statusCode}),r.push({token:":response-time",replacement:t.responseTime}),r.push({token:":date",replacement:(new Date).toUTCString()}),r.push({token:":referrer",replacement:e.headers.referer||e.headers.referrer||""}),r.push({token:":http-version",replacement:`${e.httpVersionMajor}.${e.httpVersionMinor}`}),r.push({token:":remote-addr",replacement:e.headers["x-forwarded-for"]||e.ip||e._remoteAddress||e.socket&&(e.socket.remoteAddress||e.socket.socket&&e.socket.socket.remoteAddress)}),r.push({token:":user-agent",replacement:e.headers["user-agent"]}),r.push({token:":content-length",replacement:t.getHeader("content-length")||t.__headers&&t.__headers["Content-Length"]||"-"}),r.push({token:/:req\[([^\]]+)]/g,replacement:(t,n)=>e.headers[n.toLowerCase()]}),r.push({token:/:res\[([^\]]+)]/g,replacement:(e,n)=>t.getHeader(n.toLowerCase())||t.__headers&&t.__headers[n]}),(e=>{const t=e.concat();for(let e=0;eja(e,s)));t&&n.log(r,t)}else n.log(r,ja(u,s));t.context&&n.removeContext("res")}))}return s()}},nl=Va;let rl=!1;function ul(e){if(!rl)return;Ua("Received log event ",e);Za.appendersForCategory(e.categoryName).forEach((t=>{t(e)}))}function ol(e){rl&&il();let t=e;return"string"==typeof t&&(t=function(e){Ua(`Loading configuration from ${e}`);try{return JSON.parse(Wa.readFileSync(e,"utf8"))}catch(t){throw new Error(`Problem reading config from file "${e}". Error was ${t.message}`,t)}}(e)),Ua(`Configuration is ${t}`),Ka.configure(za(t)),el.onMessage(ul),rl=!0,sl}function il(e){Ua("Shutdown called. Disabling all log writing."),rl=!1;const t=Array.from(Xa.values());Xa.init(),Za.init();const n=t.reduceRight(((e,t)=>t.shutdown?e+1:e),0);if(0===n)return Ua("No appenders with shutdown functions found."),void 0!==e&&e();let r,u=0;function o(t){r=r||t,u+=1,Ua(`Appender shutdowns complete: ${u} / ${n}`),u>=n&&(Ua("All shutdown functions completed."),e&&e(r))}return Ua(`Found ${n} appenders with shutdown functions.`),t.filter((e=>e.shutdown)).forEach((e=>e.shutdown(o))),null}const sl={getLogger:function(e){return rl||ol(process.env.LOG4JS_CONFIG||{appenders:{out:{type:"stdout"}},categories:{default:{appenders:["out"],level:"OFF"}}}),new Qa(e||"default")},configure:ol,shutdown:il,connectLogger:tl,levels:Ya,addLayout:qa.addLayout,recording:function(){return nl}};var cl=sl,al={};Object.defineProperty(al,"__esModule",{value:!0}),al.levelMap=al.getLevel=al.setCategoriesLevel=al.getConfiguration=al.setConfiguration=void 0;const ll=cl;let fl={appenders:{debug:{type:"stdout",layout:{type:"pattern",pattern:"[%d] > hvigor %p %c %[%m%]"}},info:{type:"stdout",layout:{type:"pattern",pattern:"[%d] > hvigor %[%m%]"}},"no-pattern-info":{type:"stdout",layout:{type:"pattern",pattern:"%m"}},wrong:{type:"stderr",layout:{type:"pattern",pattern:"[%d] > hvigor %[%p: %m%]"}},"just-debug":{type:"logLevelFilter",appender:"debug",level:"debug",maxLevel:"debug"},"just-info":{type:"logLevelFilter",appender:"info",level:"info",maxLevel:"info"},"just-wrong":{type:"logLevelFilter",appender:"wrong",level:"warn",maxLevel:"error"}},categories:{default:{appenders:["just-debug","just-info","just-wrong"],level:"debug"},"no-pattern-info":{appenders:["no-pattern-info"],level:"info"}}};al.setConfiguration=e=>{fl=e};al.getConfiguration=()=>fl;let dl=ll.levels.DEBUG;al.setCategoriesLevel=(e,t)=>{dl=e;const n=fl.categories;for(const r in n)(null==t?void 0:t.includes(r))||Object.prototype.hasOwnProperty.call(n,r)&&(n[r].level=e.levelStr)};al.getLevel=()=>dl,al.levelMap=new Map([["ALL",ll.levels.ALL],["MARK",ll.levels.MARK],["TRACE",ll.levels.TRACE],["DEBUG",ll.levels.DEBUG],["INFO",ll.levels.INFO],["WARN",ll.levels.WARN],["ERROR",ll.levels.ERROR],["FATAL",ll.levels.FATAL],["OFF",ll.levels.OFF]]);var Dl=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),pl=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),El=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)"default"!==n&&Object.prototype.hasOwnProperty.call(e,n)&&Dl(t,e,n);return pl(t,e),t};Object.defineProperty(xr,"__esModule",{value:!0}),xr.evaluateLogLevel=xr.HvigorLogger=void 0;const ml=El(cl),hl=cl,yl=El(F.default),Cl=al;class Fl{constructor(e){ml.configure((0,Cl.getConfiguration)()),this._logger=ml.getLogger(e),this._logger.level=(0,Cl.getLevel)()}static getLogger(e){return new Fl(e)}log(e,...t){this._logger.log(e,...t)}debug(e,...t){this._logger.debug(e,...t)}info(e,...t){this._logger.info(e,...t)}warn(e,...t){void 0!==e&&""!==e&&this._logger.warn(e,...t)}error(e,...t){this._logger.error(e,...t)}_printTaskExecuteInfo(e,t){this.info(`Finished :${e}... after ${t}`)}_printFailedTaskInfo(e){this.error(`Failed :${e}... `)}_printDisabledTaskInfo(e){this.info(`Disabled :${e}... `)}_printUpToDateTaskInfo(e){this.info(`UP-TO-DATE :${e}... `)}errorMessageExit(e,...t){throw new Error(yl.format(e,...t))}errorExit(e,t,...n){t&&this._logger.error(t,n),this._logger.error(e.stack)}setLevel(e,t){(0,Cl.setCategoriesLevel)(e,t),ml.shutdown(),ml.configure((0,Cl.getConfiguration)())}getLevel(){return this._logger.level}configure(e){const t=(0,Cl.getConfiguration)(),n={appenders:{...t.appenders,...e.appenders},categories:{...t.categories,...e.categories}};(0,Cl.setConfiguration)(n),ml.shutdown(),ml.configure(n)}}xr.HvigorLogger=Fl,xr.evaluateLogLevel=function(e,t){t.debug?e.setLevel(hl.levels.DEBUG):t.warn?e.setLevel(hl.levels.WARN):t.error?e.setLevel(hl.levels.ERROR):e.setLevel(hl.levels.INFO)};var gl=w&&w.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(X,"__esModule",{value:!0}),X.parseJsonText=X.parseJsonFile=void 0;const Al=Z,vl=gl(kr),Sl=gl(p.default),wl=gl(E.default),Ol=xr.HvigorLogger.getLogger("parse-json-util");var bl;!function(e){e[e.Char=0]="Char",e[e.EOF=1]="EOF",e[e.Identifier=2]="Identifier"}(bl||(bl={}));let _l,Bl,Pl,kl,xl,Nl,Il="start",Tl=[],Rl=0,Ml=1,Ll=0,jl=!1,$l="default",Hl="'",Jl=1;function Gl(e,t=!1){Bl=String(e),Il="start",Tl=[],Rl=0,Ml=1,Ll=0,kl=void 0,jl=t;do{_l=Vl(),Xl[Il]()}while("eof"!==_l.type);return kl}function Vl(){for($l="default",xl="",Hl="'",Jl=1;;){Nl=Ul();const e=zl[$l]();if(e)return e}}function Ul(){if(Bl[Rl])return String.fromCodePoint(Bl.codePointAt(Rl))}function Wl(){const e=Ul();return"\n"===e?(Ml++,Ll=0):e?Ll+=e.length:Ll++,e&&(Rl+=e.length),e}X.parseJsonFile=function(e,t=!1,n="utf-8"){const r=vl.default.readFileSync(Sl.default.resolve(e),{encoding:n});try{return Gl(r,t)}catch(t){if(t instanceof SyntaxError){const n=t.message.split("at");2===n.length&&Ol.errorMessageExit(`${n[0].trim()}${wl.default.EOL}\t at ${e}:${n[1].trim()}`)}Ol.errorMessageExit(`${e} is not in valid JSON/JSON5 format.`)}},X.parseJsonText=Gl;const zl={default(){switch(Nl){case"/":return Wl(),void($l="comment");case void 0:return Wl(),Kl("eof")}if(!Al.JudgeUtil.isIgnoreChar(Nl)&&!Al.JudgeUtil.isSpaceSeparator(Nl))return zl[Il]();Wl()},start(){$l="value"},beforePropertyName(){switch(Nl){case"$":case"_":return xl=Wl(),void($l="identifierName");case"\\":return Wl(),void($l="identifierNameStartEscape");case"}":return Kl("punctuator",Wl());case'"':case"'":return Hl=Nl,Wl(),void($l="string")}if(Al.JudgeUtil.isIdStartChar(Nl))return xl+=Wl(),void($l="identifierName");throw tf(bl.Char,Wl())},afterPropertyName(){if(":"===Nl)return Kl("punctuator",Wl());throw tf(bl.Char,Wl())},beforePropertyValue(){$l="value"},afterPropertyValue(){switch(Nl){case",":case"}":return Kl("punctuator",Wl())}throw tf(bl.Char,Wl())},beforeArrayValue(){if("]"===Nl)return Kl("punctuator",Wl());$l="value"},afterArrayValue(){switch(Nl){case",":case"]":return Kl("punctuator",Wl())}throw tf(bl.Char,Wl())},end(){throw tf(bl.Char,Wl())},comment(){switch(Nl){case"*":return Wl(),void($l="multiLineComment");case"/":return Wl(),void($l="singleLineComment")}throw tf(bl.Char,Wl())},multiLineComment(){switch(Nl){case"*":return Wl(),void($l="multiLineCommentAsterisk");case void 0:throw tf(bl.Char,Wl())}Wl()},multiLineCommentAsterisk(){switch(Nl){case"*":return void Wl();case"/":return Wl(),void($l="default");case void 0:throw tf(bl.Char,Wl())}Wl(),$l="multiLineComment"},singleLineComment(){switch(Nl){case"\n":case"\r":case"\u2028":case"\u2029":return Wl(),void($l="default");case void 0:return Wl(),Kl("eof")}Wl()},value(){switch(Nl){case"{":case"[":return Kl("punctuator",Wl());case"n":return Wl(),ql("ull"),Kl("null",null);case"t":return Wl(),ql("rue"),Kl("boolean",!0);case"f":return Wl(),ql("alse"),Kl("boolean",!1);case"-":case"+":return"-"===Wl()&&(Jl=-1),void($l="numerical");case".":case"0":case"I":case"N":return void($l="numerical");case'"':case"'":return Hl=Nl,Wl(),xl="",void($l="string")}if(void 0===Nl||!Al.JudgeUtil.isDigitWithoutZero(Nl))throw tf(bl.Char,Wl());$l="numerical"},numerical(){switch(Nl){case".":return xl=Wl(),void($l="decimalPointLeading");case"0":return xl=Wl(),void($l="zero");case"I":return Wl(),ql("nfinity"),Kl("numeric",Jl*(1/0));case"N":return Wl(),ql("aN"),Kl("numeric",NaN)}if(void 0!==Nl&&Al.JudgeUtil.isDigitWithoutZero(Nl))return xl=Wl(),void($l="decimalInteger");throw tf(bl.Char,Wl())},zero(){switch(Nl){case".":case"e":case"E":return void($l="decimal");case"x":case"X":return xl+=Wl(),void($l="hexadecimal")}return Kl("numeric",0)},decimalInteger(){switch(Nl){case".":case"e":case"E":return void($l="decimal")}if(!Al.JudgeUtil.isDigit(Nl))return Kl("numeric",Jl*Number(xl));xl+=Wl()},decimal(){switch(Nl){case".":xl+=Wl(),$l="decimalFraction";break;case"e":case"E":xl+=Wl(),$l="decimalExponent"}},decimalPointLeading(){if(Al.JudgeUtil.isDigit(Nl))return xl+=Wl(),void($l="decimalFraction");throw tf(bl.Char,Wl())},decimalFraction(){switch(Nl){case"e":case"E":return xl+=Wl(),void($l="decimalExponent")}if(!Al.JudgeUtil.isDigit(Nl))return Kl("numeric",Jl*Number(xl));xl+=Wl()},decimalExponent(){switch(Nl){case"+":case"-":return xl+=Wl(),void($l="decimalExponentSign")}if(Al.JudgeUtil.isDigit(Nl))return xl+=Wl(),void($l="decimalExponentInteger");throw tf(bl.Char,Wl())},decimalExponentSign(){if(Al.JudgeUtil.isDigit(Nl))return xl+=Wl(),void($l="decimalExponentInteger");throw tf(bl.Char,Wl())},decimalExponentInteger(){if(!Al.JudgeUtil.isDigit(Nl))return Kl("numeric",Jl*Number(xl));xl+=Wl()},hexadecimal(){if(Al.JudgeUtil.isHexDigit(Nl))return xl+=Wl(),void($l="hexadecimalInteger");throw tf(bl.Char,Wl())},hexadecimalInteger(){if(!Al.JudgeUtil.isHexDigit(Nl))return Kl("numeric",Jl*Number(xl));xl+=Wl()},identifierNameStartEscape(){if("u"!==Nl)throw tf(bl.Char,Wl());Wl();const e=Yl();switch(e){case"$":case"_":break;default:if(!Al.JudgeUtil.isIdStartChar(e))throw tf(bl.Identifier)}xl+=e,$l="identifierName"},identifierName(){switch(Nl){case"$":case"_":case"":case"":return void(xl+=Wl());case"\\":return Wl(),void($l="identifierNameEscape")}if(!Al.JudgeUtil.isIdContinueChar(Nl))return Kl("identifier",xl);xl+=Wl()},identifierNameEscape(){if("u"!==Nl)throw tf(bl.Char,Wl());Wl();const e=Yl();switch(e){case"$":case"_":case"":case"":break;default:if(!Al.JudgeUtil.isIdContinueChar(e))throw tf(bl.Identifier)}xl+=e,$l="identifierName"},string(){switch(Nl){case"\\":return Wl(),void(xl+=function(){const e=Ul(),t=function(){switch(Ul()){case"b":return Wl(),"\b";case"f":return Wl(),"\f";case"n":return Wl(),"\n";case"r":return Wl(),"\r";case"t":return Wl(),"\t";case"v":return Wl(),"\v"}return}();if(t)return t;switch(e){case"0":if(Wl(),Al.JudgeUtil.isDigit(Ul()))throw tf(bl.Char,Wl());return"\0";case"x":return Wl(),function(){let e="",t=Ul();if(!Al.JudgeUtil.isHexDigit(t))throw tf(bl.Char,Wl());if(e+=Wl(),t=Ul(),!Al.JudgeUtil.isHexDigit(t))throw tf(bl.Char,Wl());return e+=Wl(),String.fromCodePoint(parseInt(e,16))}();case"u":return Wl(),Yl();case"\n":case"\u2028":case"\u2029":return Wl(),"";case"\r":return Wl(),"\n"===Ul()&&Wl(),""}if(void 0===e||Al.JudgeUtil.isDigitWithoutZero(e))throw tf(bl.Char,Wl());return Wl()}());case'"':case"'":if(Nl===Hl){const e=Kl("string",xl);return Wl(),e}return void(xl+=Wl());case"\n":case"\r":case void 0:throw tf(bl.Char,Wl());case"\u2028":case"\u2029":!function(e){Ol.warn(`JSON5: '${ef(e)}' in strings is not valid ECMAScript; consider escaping.`)}(Nl)}xl+=Wl()}};function Kl(e,t){return{type:e,value:t,line:Ml,column:Ll}}function ql(e){for(const t of e){if(Ul()!==t)throw tf(bl.Char,Wl());Wl()}}function Yl(){let e="",t=4;for(;t-- >0;){const t=Ul();if(!Al.JudgeUtil.isHexDigit(t))throw tf(bl.Char,Wl());e+=Wl()}return String.fromCodePoint(parseInt(e,16))}const Xl={start(){if("eof"===_l.type)throw tf(bl.EOF);Zl()},beforePropertyName(){switch(_l.type){case"identifier":case"string":return Pl=_l.value,void(Il="afterPropertyName");case"punctuator":return void Ql();case"eof":throw tf(bl.EOF)}},afterPropertyName(){if("eof"===_l.type)throw tf(bl.EOF);Il="beforePropertyValue"},beforePropertyValue(){if("eof"===_l.type)throw tf(bl.EOF);Zl()},afterPropertyValue(){if("eof"===_l.type)throw tf(bl.EOF);switch(_l.value){case",":return void(Il="beforePropertyName");case"}":Ql()}},beforeArrayValue(){if("eof"===_l.type)throw tf(bl.EOF);"punctuator"!==_l.type||"]"!==_l.value?Zl():Ql()},afterArrayValue(){if("eof"===_l.type)throw tf(bl.EOF);switch(_l.value){case",":return void(Il="beforeArrayValue");case"]":Ql()}},end(){}};function Zl(){const e=function(){let e;switch(_l.type){case"punctuator":switch(_l.value){case"{":e={};break;case"[":e=[]}break;case"null":case"boolean":case"numeric":case"string":e=_l.value}return e}();if(jl&&"object"==typeof e&&(e._line=Ml,e._column=Ll),void 0===kl)kl=e;else{const t=Tl[Tl.length-1];Array.isArray(t)?jl&&"object"!=typeof e?t.push({value:e,_line:Ml,_column:Ll}):t.push(e):t[Pl]=jl&&"object"!=typeof e?{value:e,_line:Ml,_column:Ll}:e}!function(e){if(e&&"object"==typeof e)Tl.push(e),Il=Array.isArray(e)?"beforeArrayValue":"beforePropertyName";else{const e=Tl[Tl.length-1];Il=e?Array.isArray(e)?"afterArrayValue":"afterPropertyValue":"end"}}(e)}function Ql(){Tl.pop();const e=Tl[Tl.length-1];Il=e?Array.isArray(e)?"afterArrayValue":"afterPropertyValue":"end"}function ef(e){const t={"'":"\\'",'"':'\\"',"\\":"\\\\","\b":"\\b","\f":"\\f","\n":"\\n","\r":"\\r","\t":"\\t","\v":"\\v","\0":"\\0","\u2028":"\\u2028","\u2029":"\\u2029"};if(t[e])return t[e];if(e<" "){const t=e.charCodeAt(0).toString(16);return`\\x${`00${t}`.substring(t.length)}`}return e}function tf(e,t){let n="";switch(e){case bl.Char:n=void 0===t?`JSON5: invalid end of input at ${Ml}:${Ll}`:`JSON5: invalid character '${ef(t)}' at ${Ml}:${Ll}`;break;case bl.EOF:n=`JSON5: invalid end of input at ${Ml}:${Ll}`;break;case bl.Identifier:Ll-=5,n=`JSON5: invalid identifier character at ${Ml}:${Ll}`}const r=new nf(n);return r.lineNumber=Ml,r.columnNumber=Ll,r}class nf extends SyntaxError{}var rf=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),uf=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),of=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)"default"!==n&&Object.prototype.hasOwnProperty.call(e,n)&&rf(t,e,n);return uf(t,e),t};Object.defineProperty(Y,"__esModule",{value:!0});var sf=Y.cleanWorkSpace=Ff=Y.executeInstallHvigor=yf=Y.isHvigorInstalled=mf=Y.isAllDependenciesInstalled=void 0;const cf=of(D.default),af=of(p.default),lf=b,ff=j,df=$,Df=X;let pf,Ef;var mf=Y.isAllDependenciesInstalled=function(){function e(e){const t=null==e?void 0:e.dependencies;return void 0===t?0:Object.getOwnPropertyNames(t).length}if(pf=gf(),Ef=Af(),e(pf)+1!==e(Ef))return!1;for(const e in null==pf?void 0:pf.dependencies)if(!(0,ff.hasNpmPackInPaths)(e,[lf.HVIGOR_PROJECT_DEPENDENCIES_HOME])||!hf(e,pf,Ef))return!1;return!0};function hf(e,t,n){return void 0!==n.dependencies&&(0,ff.offlinePluginConversion)(lf.HVIGOR_PROJECT_ROOT_DIR,t.dependencies[e])===n.dependencies[e]}var yf=Y.isHvigorInstalled=function(){return pf=gf(),Ef=Af(),(0,ff.hasNpmPackInPaths)(lf.HVIGOR_ENGINE_PACKAGE_NAME,[lf.HVIGOR_PROJECT_DEPENDENCIES_HOME])&&(0,ff.offlinePluginConversion)(lf.HVIGOR_PROJECT_ROOT_DIR,pf.hvigorVersion)===Ef.dependencies[lf.HVIGOR_ENGINE_PACKAGE_NAME]};const Cf={cwd:lf.HVIGOR_PROJECT_DEPENDENCIES_HOME,stdio:["inherit","inherit","inherit"]};var Ff=Y.executeInstallHvigor=function(){(0,df.logInfoPrintConsole)("Hvigor installing...");const e={dependencies:{}};e.dependencies[lf.HVIGOR_ENGINE_PACKAGE_NAME]=(0,ff.offlinePluginConversion)(lf.HVIGOR_PROJECT_ROOT_DIR,pf.hvigorVersion);try{cf.mkdirSync(lf.HVIGOR_PROJECT_DEPENDENCIES_HOME,{recursive:!0});const t=af.resolve(lf.HVIGOR_PROJECT_DEPENDENCIES_HOME,lf.DEFAULT_PACKAGE_JSON);cf.writeFileSync(t,JSON.stringify(e))}catch(e){(0,df.logErrorAndExit)(e)}!function(){const e=["config","set","store-dir",lf.HVIGOR_PNPM_STORE_PATH];(0,ff.executeCommand)(lf.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH,e,Cf)}(),(0,ff.executeCommand)(lf.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH,["install"],Cf)};function gf(){const e=af.resolve(lf.HVIGOR_PROJECT_WRAPPER_HOME,lf.DEFAULT_HVIGOR_CONFIG_JSON_FILE_NAME);return cf.existsSync(e)||(0,df.logErrorAndExit)(`Error: Hvigor config file ${e} does not exist.`),(0,Df.parseJsonFile)(e)}function Af(){return cf.existsSync(lf.HVIGOR_PROJECT_DEPENDENCY_PACKAGE_JSON_PATH)?(0,Df.parseJsonFile)(lf.HVIGOR_PROJECT_DEPENDENCY_PACKAGE_JSON_PATH):{dependencies:{}}}sf=Y.cleanWorkSpace=function(){if((0,df.logInfoPrintConsole)("Hvigor cleaning..."),!cf.existsSync(lf.HVIGOR_PROJECT_DEPENDENCIES_HOME))return;const e=cf.readdirSync(lf.HVIGOR_PROJECT_DEPENDENCIES_HOME);if(e&&0!==e.length){cf.existsSync(lf.HVIGOR_BOOT_JS_FILE_PATH)&&(0,ff.executeCommand)(process.argv[0],[lf.HVIGOR_BOOT_JS_FILE_PATH,"--stop-daemon"],{});try{e.forEach((e=>{cf.rmSync(af.resolve(lf.HVIGOR_PROJECT_DEPENDENCIES_HOME,e),{recursive:!0})}))}catch(e){(0,df.logErrorAndExit)(`The hvigor build tool cannot be installed. Please manually clear the workspace directory and synchronize the project again.\n\n Workspace Path: ${lf.HVIGOR_PROJECT_DEPENDENCIES_HOME}.`)}}};var vf={},Sf=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),wf=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),Of=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)"default"!==n&&Object.prototype.hasOwnProperty.call(e,n)&&Sf(t,e,n);return wf(t,e),t};Object.defineProperty(vf,"__esModule",{value:!0});var bf=vf.executeBuild=void 0;const _f=b,Bf=Of(D.default),Pf=Of(p.default),kf=$;bf=vf.executeBuild=function(){const e=Pf.resolve(_f.HVIGOR_PROJECT_DEPENDENCIES_HOME,"node_modules","@ohos","hvigor","bin","hvigor.js");try{const t=Bf.realpathSync(e);require(t)}catch(t){(0,kf.logErrorAndExit)(`Error: ENOENT: no such file ${e},delete ${_f.HVIGOR_PROJECT_DEPENDENCIES_HOME} and retry.`)}},function(){if(O.checkNpmConifg(),O.environmentHandler(),O.isPnpmAvailable()||O.executeInstallPnpm(),yf()&&mf())bf();else{sf();try{Ff()}catch(e){return void sf()}bf()}}();
\ No newline at end of file
diff --git a/storage/storagefileurijstest/hvigorfile.ts b/storage/storagefileurijstest/hvigorfile.ts
deleted file mode 100644
index 0b9c10fc3ade5a54609b2d639f808ca7c25a611a..0000000000000000000000000000000000000000
--- a/storage/storagefileurijstest/hvigorfile.ts
+++ /dev/null
@@ -1,16 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-// Script for compiling build behavior. It is built in the build plug-in and cannot be modified currently.
-export { legacyAppTasks } from '@ohos/hvigor-ohos-plugin';
\ No newline at end of file
diff --git a/storage/storagefileurijstest/hvigorw b/storage/storagefileurijstest/hvigorw
deleted file mode 100755
index b4d7760e72934718fc616fcef2806a1c7f04ba34..0000000000000000000000000000000000000000
--- a/storage/storagefileurijstest/hvigorw
+++ /dev/null
@@ -1,61 +0,0 @@
-# Copyright (c) 2023 Huawei Device Co., Ltd.
-# Licensed under the Apache License, Version 2.0 (the "License");
-# you may not use this file except in compliance with the License.
-# You may obtain a copy of the License at
-#
-# http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-
-#!/bin/bash
-
-# ----------------------------------------------------------------------------
-# Hvigor startup script, version 1.0.0
-#
-# Required ENV vars:
-# ------------------
-# NODE_HOME - location of a Node home dir
-# or
-# Add /usr/local/nodejs/bin to the PATH environment variable
-# ----------------------------------------------------------------------------
-
-HVIGOR_APP_HOME=$(dirname $(readlink -f $0))
-HVIGOR_WRAPPER_SCRIPT=${HVIGOR_APP_HOME}/hvigor/hvigor-wrapper.js
-warn() {
- echo ""
- echo -e "\033[1;33m`date '+[%Y-%m-%d %H:%M:%S]'`$@\033[0m"
-}
-
-error() {
- echo ""
- echo -e "\033[1;31m`date '+[%Y-%m-%d %H:%M:%S]'`$@\033[0m"
-}
-
-fail() {
- error "$@"
- exit 1
-}
-
-# Determine node to start hvigor wrapper script
-if [ -n "${NODE_HOME}" ];then
- EXECUTABLE_NODE="${NODE_HOME}/bin/node"
- if [ ! -x "$EXECUTABLE_NODE" ];then
- fail "ERROR: NODE_HOME is set to an invalid directory,check $NODE_HOME\n\nPlease set NODE_HOME in your environment to the location where your nodejs installed"
- fi
-else
- EXECUTABLE_NODE="node"
- which ${EXECUTABLE_NODE} > /dev/null 2>&1 || fail "ERROR: NODE_HOME is not set and not 'node' command found in your path"
-fi
-
-# Check hvigor wrapper script
-if [ ! -r "$HVIGOR_WRAPPER_SCRIPT" ];then
- fail "ERROR: Couldn't find hvigor/hvigor-wrapper.js in ${HVIGOR_APP_HOME}"
-fi
-
-# start hvigor-wrapper script
-exec "${EXECUTABLE_NODE}" \
- "${HVIGOR_WRAPPER_SCRIPT}" "$@"
diff --git a/storage/storagefileurijstest/hvigorw.bat b/storage/storagefileurijstest/hvigorw.bat
deleted file mode 100644
index a9cc1302dc821de7f9f82c3327673a730945ec7d..0000000000000000000000000000000000000000
--- a/storage/storagefileurijstest/hvigorw.bat
+++ /dev/null
@@ -1,70 +0,0 @@
-@rem Copyright (C) 2023 Huawei Device Co., Ltd.
-@rem Licensed under the Apache License, Version 2.0 (the "License");
-@rem you may not use this file except in compliance with the License.
-@rem You may obtain a copy of the License at
-@rem
-@rem http://www.apache.org/licenses/LICENSE-2.0
-@rem
-@rem Unless required by applicable law or agreed to in writing, software
-@rem distributed under the License is distributed on an "AS IS" BASIS,
-@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-@rem See the License for the specific language governing permissions and
-@rem limitations under the License.
-
-@if "%DEBUG%" == "" @echo off
-@rem ##########################################################################
-@rem
-@rem Hvigor startup script for Windows
-@rem
-@rem ##########################################################################
-
-@rem Set local scope for the variables with windows NT shell
-if "%OS%"=="Windows_NT" setlocal
-
-set DIRNAME=%~dp0
-if "%DIRNAME%" == "" set DIRNAME=.
-set APP_BASE_NAME=%~n0
-set APP_HOME=%DIRNAME%
-
-@rem Resolve any "." and ".." in APP_HOME to make it shorter.
-for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi
-
-set WRAPPER_MODULE_PATH=%APP_HOME%\hvigor\hvigor-wrapper.js
-set NODE_EXE=node.exe
-
-goto start
-
-:start
-@rem Find node.exe
-if defined NODE_HOME goto findNodeFromNodeHome
-
-%NODE_EXE% --version >NUL 2>&1
-if "%ERRORLEVEL%" == "0" goto execute
-
-echo.
-echo ERROR: NODE_HOME is not set and no 'node' command could be found in your PATH.
-echo.
-echo Please set the NODE_HOME variable in your environment to match the
-echo location of your NodeJs installation.
-
-goto fail
-
-:findNodeFromNodeHome
-set NODE_HOME=%NODE_HOME:"=%
-set NODE_EXE_PATH=%NODE_HOME%/%NODE_EXE%
-
-if exist "%NODE_EXE_PATH%" goto execute
-echo.
-echo ERROR: NODE_HOME is not set and no 'node' command could be found in your PATH.
-echo.
-echo Please set the NODE_HOME variable in your environment to match the
-echo location of your NodeJs installation.
-
-goto fail
-
-:execute
-@rem Execute hvigor
-"%NODE_EXE%" %WRAPPER_MODULE_PATH% %*
-
-:fail
-exit /b 1
diff --git a/storage/storagefileurijstest/oh-package.json5 b/storage/storagefileurijstest/oh-package.json5
deleted file mode 100644
index 1a98aac1810691829d1f9908395de4863cb0623d..0000000000000000000000000000000000000000
--- a/storage/storagefileurijstest/oh-package.json5
+++ /dev/null
@@ -1,26 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-{
- "license": "",
- "devDependencies": {
- "@ohos/hypium": "1.0.6"
- },
- "author": "",
- "name": "myapplication454434",
- "description": "Please describe the basic information.",
- "main": "",
- "version": "1.0.0",
- "dependencies": {}
-}
diff --git a/storage/storagefileurijstest/signature/openharmony_sx.p7b b/storage/storagefileurijstest/signature/openharmony_sx.p7b
index bede37b2b89fdd4203c70cd3cd100e8c647aab55..33e5146b419e5f79cb81d759cb782a1017a21d33 100644
Binary files a/storage/storagefileurijstest/signature/openharmony_sx.p7b and b/storage/storagefileurijstest/signature/openharmony_sx.p7b differ
diff --git a/storage/storagefileurijstest/src/main/config.json b/storage/storagefileurijstest/src/main/config.json
new file mode 100644
index 0000000000000000000000000000000000000000..3c1bbd664eb08bcca3329c7fe14405e78e38d7ed
--- /dev/null
+++ b/storage/storagefileurijstest/src/main/config.json
@@ -0,0 +1,96 @@
+{
+ "app": {
+ "bundleName": "ohos.acts.storage.fileuri",
+ "vendor": "example",
+ "version": {
+ "code": 1000000,
+ "name": "1.0.0"
+ },
+ "apiVersion": {
+ "compatible": 8,
+ "target": 9
+ }
+ },
+ "deviceConfig": {},
+ "module": {
+ "package": "ohos.acts.storage.fileuri",
+ "name": ".entry",
+ "deviceType": [
+ "tablet",
+ "default",
+ "phone"
+ ],
+ "distro": {
+ "deliveryWithInstall": true,
+ "moduleName": "entry",
+ "moduleType": "entry",
+ "installationFree": true
+ },
+ "abilities": [
+ {
+ "skills": [
+ {
+ "entities": [
+ "entity.system.home"
+ ],
+ "actions": [
+ "action.system.home"
+ ]
+ }
+ ],
+ "orientation": "unspecified",
+ "formsEnabled": false,
+ "name": ".MainAbility",
+ "srcLanguage": "js",
+ "srcPath": "MainAbility",
+ "icon": "$media:icon",
+ "description": "$string:MainAbility_desc",
+ "label": "$string:MainAbility_label",
+ "type": "page",
+ "visible": true,
+ "launchType": "standard"
+ },
+ {
+ "orientation": "unspecified",
+ "formsEnabled": false,
+ "name": ".TestAbility",
+ "srcLanguage": "js",
+ "srcPath": "TestAbility",
+ "icon": "$media:icon",
+ "description": "$string:TestAbility_desc",
+ "label": "$string:TestAbility_label",
+ "type": "page",
+ "visible": true,
+ "launchType": "standard"
+ }
+ ],
+ "js": [
+ {
+ "pages": [
+ "pages/index/index"
+ ],
+ "name": "default",
+ "window": {
+ "designWidth": 720,
+ "autoDesignWidth": false
+ }
+ },
+ {
+ "pages": [
+ "pages/index/index"
+ ],
+ "name": ".TestAbility",
+ "window": {
+ "designWidth": 720,
+ "autoDesignWidth": false
+ }
+ }
+ ],
+ "testRunner": {
+ "name": "OpenHarmonyTestRunner",
+ "srcPath": "TestRunner"
+ },
+ "mainAbility": ".MainAbility",
+ "srcPath": ""
+ }
+}
\ No newline at end of file
diff --git a/storage/storagefileurijstest/src/main/js/MainAbility/app.js b/storage/storagefileurijstest/src/main/js/MainAbility/app.js
new file mode 100644
index 0000000000000000000000000000000000000000..3a55a2493b2e5a4a01de2c4104ec33b5105aee84
--- /dev/null
+++ b/storage/storagefileurijstest/src/main/js/MainAbility/app.js
@@ -0,0 +1,23 @@
+/*
+ * Copyright (C) 2022 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+export default {
+ onCreate() {
+ console.info('ohos.acts.storage.fileuri onCreate');
+ },
+ onDestroy() {
+ console.info('ohos.acts.storage.fileuri onDestroy');
+ }
+};
diff --git a/storage/storagesecuritylabeljstest/entry/src/main/js/MainAbility/i18n/en-US.json b/storage/storagefileurijstest/src/main/js/MainAbility/i18n/en-US.json
similarity index 61%
rename from storage/storagesecuritylabeljstest/entry/src/main/js/MainAbility/i18n/en-US.json
rename to storage/storagefileurijstest/src/main/js/MainAbility/i18n/en-US.json
index a4c13dcbdc39c537073f638393d7726ac9a5cdc4..ead52ed2e09ec82aaf7aa9f4e714ed39ea88308e 100644
--- a/storage/storagesecuritylabeljstest/entry/src/main/js/MainAbility/i18n/en-US.json
+++ b/storage/storagefileurijstest/src/main/js/MainAbility/i18n/en-US.json
@@ -1,6 +1,6 @@
-{
- "strings": {
- "hello": "Hello",
- "world": "World"
- }
+{
+ "strings": {
+ "hello": "Hello",
+ "world": "Test"
+ }
}
\ No newline at end of file
diff --git a/storage/storagefileurijstest/entry/src/main/js/MainAbility/i18n/zh-CN.json b/storage/storagefileurijstest/src/main/js/MainAbility/i18n/zh-CN.json
similarity index 61%
rename from storage/storagefileurijstest/entry/src/main/js/MainAbility/i18n/zh-CN.json
rename to storage/storagefileurijstest/src/main/js/MainAbility/i18n/zh-CN.json
index b1c02368f72f929e4375a43170444de95dcc5984..3f48f2585b24a8fe4a745e8ee2972a9e991a7803 100644
--- a/storage/storagefileurijstest/entry/src/main/js/MainAbility/i18n/zh-CN.json
+++ b/storage/storagefileurijstest/src/main/js/MainAbility/i18n/zh-CN.json
@@ -1,6 +1,6 @@
-{
- "strings": {
- "hello": "您好",
- "world": "世界"
- }
+{
+ "strings": {
+ "hello": "您好",
+ "world": "测试"
+ }
}
\ No newline at end of file
diff --git a/storage/storagefileurijstest/src/main/js/MainAbility/pages/index/index.css b/storage/storagefileurijstest/src/main/js/MainAbility/pages/index/index.css
new file mode 100644
index 0000000000000000000000000000000000000000..6fda792753f2e15f22b529c7b90a82185b2770bf
--- /dev/null
+++ b/storage/storagefileurijstest/src/main/js/MainAbility/pages/index/index.css
@@ -0,0 +1,9 @@
+.container {
+ flex-direction: column;
+ justify-content: center;
+ align-items: center;
+}
+
+.title {
+ font-size: 100px;
+}
diff --git a/storage/storagestatfsjstest/entry/src/ohosTest/js/TestAbility/pages/index/index.hml b/storage/storagefileurijstest/src/main/js/MainAbility/pages/index/index.hml
similarity index 100%
rename from storage/storagestatfsjstest/entry/src/ohosTest/js/TestAbility/pages/index/index.hml
rename to storage/storagefileurijstest/src/main/js/MainAbility/pages/index/index.hml
diff --git a/storage/storagefileurijstest/src/main/js/MainAbility/pages/index/index.js b/storage/storagefileurijstest/src/main/js/MainAbility/pages/index/index.js
new file mode 100644
index 0000000000000000000000000000000000000000..9049ac0ecdc4fcd36d2a44ca1808a30413dfeed0
--- /dev/null
+++ b/storage/storagefileurijstest/src/main/js/MainAbility/pages/index/index.js
@@ -0,0 +1,34 @@
+/*
+ * Copyright (C) 2022 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import app from '@system.app'
+
+
+const injectRef = Object.getPrototypeOf(global) || global
+injectRef.regeneratorRuntime = require('@babel/runtime/regenerator')
+
+export default {
+ data: {
+ title: ''
+ },
+ onInit() {
+ this.title = this.$t('strings.world');
+ },
+ onShow() {
+ console.info('onShow finish')
+ },
+ onReady() {
+ },
+}
\ No newline at end of file
diff --git a/storage/storagesecuritylabeljstest/entry/src/ohosTest/js/TestAbility/app.js b/storage/storagefileurijstest/src/main/js/TestAbility/app.js
similarity index 62%
rename from storage/storagesecuritylabeljstest/entry/src/ohosTest/js/TestAbility/app.js
rename to storage/storagefileurijstest/src/main/js/TestAbility/app.js
index 469c4f1380182e0dccb04f17eb95d9b503a56d29..cdc31f3dcf031e2f6a7665d9653e53bb649e21c5 100644
--- a/storage/storagesecuritylabeljstest/entry/src/ohosTest/js/TestAbility/app.js
+++ b/storage/storagefileurijstest/src/main/js/TestAbility/app.js
@@ -1,5 +1,5 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
+/*
+ * Copyright (c) 2022 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
@@ -12,22 +12,20 @@
* See the License for the specific language governing permissions and
* limitations under the License.
*/
-import hilog from '@ohos.hilog';
-import AbilityDelegatorRegistry from '@ohos.app.ability.abilityDelegatorRegistry';
-import { Hypium } from '@ohos/hypium';
-import testsuite from '../test/List.test';
+
+import AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry'
+import { Hypium } from '@ohos/hypium'
+import testsuite from '../test/List.test'
export default {
onCreate() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'TestApplication onCreate');
+ console.info('TestApplication onCreate')
var abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator()
var abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments()
- hilog.info(0x0000, 'testTag', '%{public}s', 'start run testcase!!!');
+ console.info('start run testcase!!!')
Hypium.hypiumTest(abilityDelegator, abilityDelegatorArguments, testsuite)
},
onDestroy() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'TestApplication onDestroy');
+ console.info("TestApplication onDestroy");
}
};
-
-
diff --git a/storage/storagefilejstest/entry/src/ohosTest/js/TestAbility/i18n/en-US.json b/storage/storagefileurijstest/src/main/js/TestAbility/i18n/en-US.json
similarity index 100%
rename from storage/storagefilejstest/entry/src/ohosTest/js/TestAbility/i18n/en-US.json
rename to storage/storagefileurijstest/src/main/js/TestAbility/i18n/en-US.json
diff --git a/storage/storagefilejstest/entry/src/ohosTest/js/TestAbility/i18n/zh-CN.json b/storage/storagefileurijstest/src/main/js/TestAbility/i18n/zh-CN.json
similarity index 100%
rename from storage/storagefilejstest/entry/src/ohosTest/js/TestAbility/i18n/zh-CN.json
rename to storage/storagefileurijstest/src/main/js/TestAbility/i18n/zh-CN.json
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/TestAbility/pages/index/index.css b/storage/storagefileurijstest/src/main/js/TestAbility/pages/index/index.css
similarity index 100%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/TestAbility/pages/index/index.css
rename to storage/storagefileurijstest/src/main/js/TestAbility/pages/index/index.css
diff --git a/storage/storagefileurijstest/src/main/js/TestAbility/pages/index/index.hml b/storage/storagefileurijstest/src/main/js/TestAbility/pages/index/index.hml
new file mode 100644
index 0000000000000000000000000000000000000000..f629c71a9be857db6cdf94149652a191b9b272ea
--- /dev/null
+++ b/storage/storagefileurijstest/src/main/js/TestAbility/pages/index/index.hml
@@ -0,0 +1,5 @@
+
+
+ {{ $t('strings.hello') }} {{ title }}
+
+
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/TestAbility/pages/index/index.js b/storage/storagefileurijstest/src/main/js/TestAbility/pages/index/index.js
similarity index 90%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/TestAbility/pages/index/index.js
rename to storage/storagefileurijstest/src/main/js/TestAbility/pages/index/index.js
index ad113c0d214ce0d80c42c75c62d881547b6294ee..88b083a7f6b979019d6a2c5ad20b19c5fd43286b 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/TestAbility/pages/index/index.js
+++ b/storage/storagefileurijstest/src/main/js/TestAbility/pages/index/index.js
@@ -1,25 +1,26 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-export default {
- data: {
- title: ""
- },
- onInit() {
- this.title = this.$t('strings.world');
- }
-}
-
-
-
+/*
+ * Copyright (c) 2022 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+export default {
+ data: {
+ title: ""
+ },
+ onInit() {
+ this.title = this.$t('strings.world');
+ }
+}
+
+
+
diff --git a/storage/storagefileiov9jstest/entry/src/ohosTest/js/TestRunner/OpenHarmonyTestRunner.js b/storage/storagefileurijstest/src/main/js/TestRunner/OpenHarmonyTestRunner.js
similarity index 51%
rename from storage/storagefileiov9jstest/entry/src/ohosTest/js/TestRunner/OpenHarmonyTestRunner.js
rename to storage/storagefileurijstest/src/main/js/TestRunner/OpenHarmonyTestRunner.js
index 03ccc5b691574b1d5bc46adefc08d9ddfc4a1f5c..c5fa8620ca77d381f20b65a903b833e6e3378c97 100644
--- a/storage/storagefileiov9jstest/entry/src/ohosTest/js/TestRunner/OpenHarmonyTestRunner.js
+++ b/storage/storagefileurijstest/src/main/js/TestRunner/OpenHarmonyTestRunner.js
@@ -1,41 +1,59 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-import hilog from '@ohos.hilog';
-import AbilityDelegatorRegistry from '@ohos.app.ability.abilityDelegatorRegistry';
-
- export default {
- onPrepare() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'OpenHarmonyTestRunner OnPrepare');
- },
- onRun() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'OpenHarmonyTestRunner onRun run');
- var abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments()
- var abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator()
-
- var testAbilityName = abilityDelegatorArguments.parameters['-p'] + '.TestAbility'
- var cmd = 'aa start -d 0 -a ' + testAbilityName + ' -b ' + abilityDelegatorArguments.bundleName
- var debug = abilityDelegatorArguments.parameters["-D"]
- if (debug == 'true')
- {
- cmd += ' -D'
- }
- hilog.info(0x0000, 'testTag', 'cmd : %{public}s', cmd);
- abilityDelegator.executeShellCommand(cmd, (err, data) => {
- hilog.info(0x0000, 'testTag', 'executeShellCommand : err : %{public}s', JSON.stringify(err) ?? '');
- hilog.info(0x0000, 'testTag', 'executeShellCommand : data : %{public}s', data.stdResult ?? '');
- hilog.info(0x0000, 'testTag', 'executeShellCommand : data : %{public}s', data.exitCode ?? '');
- })
- }
-};
\ No newline at end of file
+/*
+ * Copyright (c) 2022 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry'
+
+function translateParamsToString(parameters) {
+ const keySet = new Set([
+ '-s class', '-s notClass', '-s suite', '-s itName',
+ '-s level', '-s testType', '-s size', '-s timeout',
+ '-s package', '-s dryRun'
+ ])
+ let targetParams = '';
+ for (const key in parameters) {
+ if (keySet.has(key)) {
+ targetParams += ' ' + key + ' ' + parameters[key]
+ }
+ }
+ return targetParams.trim()
+}
+
+ export default {
+ onPrepare() {
+ console.info('OpenHarmonyTestRunner OnPrepare')
+ },
+ onRun() {
+ console.log('OpenHarmonyTestRunner onRun run')
+ var abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments()
+ var abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator()
+
+ var testAbilityName = abilityDelegatorArguments.parameters['-p'] + '.TestAbility'
+
+ var cmd = 'aa start -d 0 -a ' + testAbilityName + ' -b ' + abilityDelegatorArguments.bundleName
+ cmd += ' ' + translateParamsToString(abilityDelegatorArguments.parameters)
+ var debug = abilityDelegatorArguments.parameters["-D"]
+ console.info('debug value : '+debug)
+ if (debug == 'true')
+ {
+ cmd += ' -D'
+ }
+ console.info('cmd : '+cmd)
+ abilityDelegator.executeShellCommand(cmd, (err, data) => {
+ console.info('executeShellCommand : err : ' + JSON.stringify(err));
+ console.info('executeShellCommand : data : ' + data.stdResult);
+ console.info('executeShellCommand : data : ' + data.exitCode);
+ })
+ }
+};
diff --git a/storage/storagefileurijstest/entry/src/ohosTest/js/test/List.test.js b/storage/storagefileurijstest/src/main/js/test/List.test.js
similarity index 90%
rename from storage/storagefileurijstest/entry/src/ohosTest/js/test/List.test.js
rename to storage/storagefileurijstest/src/main/js/test/List.test.js
index 7f215f52d8c97f0261e93e9bdc9e9cb0541cd215..1f7817abc770fbce3a9be59d426161c5a9e3a84f 100644
--- a/storage/storagefileurijstest/entry/src/ohosTest/js/test/List.test.js
+++ b/storage/storagefileurijstest/src/main/js/test/List.test.js
@@ -1,5 +1,5 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
+/*
+ * Copyright (C) 2022 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
diff --git a/storage/storagefileurijstest/entry/src/ohosTest/js/test/fileuri.test.js b/storage/storagefileurijstest/src/main/js/test/fileuri.test.js
similarity index 92%
rename from storage/storagefileurijstest/entry/src/ohosTest/js/test/fileuri.test.js
rename to storage/storagefileurijstest/src/main/js/test/fileuri.test.js
index 087c320834f733b1bcc4d99fe7385865f8f08130..cbc5dbad501c3672c11ce858b8f07eef09bc4a3d 100644
--- a/storage/storagefileurijstest/entry/src/ohosTest/js/test/fileuri.test.js
+++ b/storage/storagefileurijstest/src/main/js/test/fileuri.test.js
@@ -1,13 +1,13 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
+/*
+ * Copyright (C) 2022 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
+ * distributed under the License is distributed on an 'AS IS' BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
diff --git a/storage/storagefileurijstest/entry/src/main/resources/base/element/string.json b/storage/storagefileurijstest/src/main/resources/base/element/string.json
similarity index 100%
rename from storage/storagefileurijstest/entry/src/main/resources/base/element/string.json
rename to storage/storagefileurijstest/src/main/resources/base/element/string.json
diff --git a/storage/storagefilejstest/entry/src/main/resources/base/media/icon.png b/storage/storagefileurijstest/src/main/resources/base/media/icon.png
similarity index 100%
rename from storage/storagefilejstest/entry/src/main/resources/base/media/icon.png
rename to storage/storagefileurijstest/src/main/resources/base/media/icon.png
diff --git a/storage/storagesecuritylabeljstest/BUILD.gn b/storage/storagesecuritylabeljstest/BUILD.gn
index 94640d14fd95e361b10d161b401bb924a2be3e6e..1797f065f80224aa4589c975d170a22700758b12 100644
--- a/storage/storagesecuritylabeljstest/BUILD.gn
+++ b/storage/storagesecuritylabeljstest/BUILD.gn
@@ -1,4 +1,4 @@
-# Copyright (c) 2023 Huawei Device Co., Ltd.
+# Copyright (C) 2021 Huawei Device Co., Ltd.
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
@@ -13,11 +13,23 @@
import("//test/xts/tools/build/suite.gni")
-ohos_js_app_suite("storagesecuritylabel_js_test") {
- test_hap = true
- testonly = true
+ohos_js_hap_suite("storagesecuritylabel_js_test") {
+ hap_profile = "./src/main/config.json"
+ deps = [
+ ":storagesecuritylabel_js_assets",
+ ":storagesecuritylabel_js_resources",
+ ]
+ certificate_profile = "./signature/openharmony_sx.p7b"
hap_name = "ActsStorageSecurityLabelJSTest"
subsystem_name = "filemanagement"
part_name = "file_api"
- certificate_profile = "./signature/openharmony_sx.p7b"
+}
+ohos_js_assets("storagesecuritylabel_js_assets") {
+ js2abc = true
+ hap_profile = "./src/main/config.json"
+ source_dir = "./src/main/js"
+}
+ohos_resources("storagesecuritylabel_js_resources") {
+ sources = [ "./src/main/resources" ]
+ hap_profile = "./src/main/config.json"
}
diff --git a/storage/storagesecuritylabeljstest/Test.json b/storage/storagesecuritylabeljstest/Test.json
index eb435e2f4127f211bc010d4af46704e63054a152..600c9a4db1e0ce063bcffb458b17369c77f69bcb 100644
--- a/storage/storagesecuritylabeljstest/Test.json
+++ b/storage/storagesecuritylabeljstest/Test.json
@@ -5,7 +5,7 @@
"test-timeout": "60000",
"shell-timeout": "60000",
"bundle-name": "ohos.acts.storage.securitylabel",
- "package-name": "ohos.acts.storage.securitylabel_test"
+ "package-name": "ohos.acts.storage.securitylabel"
},
"kits": [
{
diff --git a/storage/storagesecuritylabeljstest/build-profile.json5 b/storage/storagesecuritylabeljstest/build-profile.json5
deleted file mode 100644
index 7715cddc0112e0e0c8e40623b77ff67b82731829..0000000000000000000000000000000000000000
--- a/storage/storagesecuritylabeljstest/build-profile.json5
+++ /dev/null
@@ -1,42 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-{
- "app": {
- "signingConfigs": [
- ],
- "compileSdkVersion": 10,
- "compatibleSdkVersion": 10,
- "products": [
- {
- "name": "default",
- "signingConfig": "default"
- }
- ]
- },
- "modules": [
- {
- "name": "entry",
- "srcPath": "./entry",
- "targets": [
- {
- "name": "default",
- "applyToProducts": [
- "default"
- ]
- }
- ]
- }
- ]
-}
\ No newline at end of file
diff --git a/storage/storagesecuritylabeljstest/entry/build-profile.json5 b/storage/storagesecuritylabeljstest/entry/build-profile.json5
deleted file mode 100644
index a6a17e6971173aacea7b75d9ae897a80d335dc0b..0000000000000000000000000000000000000000
--- a/storage/storagesecuritylabeljstest/entry/build-profile.json5
+++ /dev/null
@@ -1,27 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-{
- "apiType": 'faMode',
- "buildOption": {
- },
- "targets": [
- {
- "name": "default",
- },
- {
- "name": "ohosTest",
- }
- ]
-}
\ No newline at end of file
diff --git a/storage/storagesecuritylabeljstest/entry/hvigorfile.ts b/storage/storagesecuritylabeljstest/entry/hvigorfile.ts
deleted file mode 100644
index ec27aa45d8977eac23d7a5af6850d1a1e958ab0f..0000000000000000000000000000000000000000
--- a/storage/storagesecuritylabeljstest/entry/hvigorfile.ts
+++ /dev/null
@@ -1,17 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-// Script for compiling build behavior. It is built in the build plug-in and cannot be modified currently.
-export { legacyHapTasks } from '@ohos/hvigor-ohos-plugin';
diff --git a/storage/storagesecuritylabeljstest/entry/oh-package.json5 b/storage/storagesecuritylabeljstest/entry/oh-package.json5
deleted file mode 100644
index 75ca1d70feb1c490379299fe342058a2a7183388..0000000000000000000000000000000000000000
--- a/storage/storagesecuritylabeljstest/entry/oh-package.json5
+++ /dev/null
@@ -1,24 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-{
- "license": "",
- "devDependencies": {},
- "author": "",
- "name": "entry",
- "description": "Please describe the basic information.",
- "main": "",
- "version": "1.0.0",
- "dependencies": {}
-}
diff --git a/storage/storagesecuritylabeljstest/entry/src/main/config.json b/storage/storagesecuritylabeljstest/entry/src/main/config.json
deleted file mode 100644
index 023938f140c5689b460764d2d35b0845559654b3..0000000000000000000000000000000000000000
--- a/storage/storagesecuritylabeljstest/entry/src/main/config.json
+++ /dev/null
@@ -1,65 +0,0 @@
-{
- "app":{
- "bundleName":"ohos.acts.storage.securitylabel",
- "vendor":"example",
- "version":{
- "code":1000000,
- "name":"1.0.0"
- }
- },
- "deviceConfig":{
-
- },
- "module":{
- "package":"ohos.acts.storage.securitylabel",
- "name":".entry",
- "mainAbility":".MainAbility",
- "deviceType": [
- "tablet",
- "default"
- ],
- "distro":{
- "deliveryWithInstall":true,
- "installationFree":true,
- "moduleName":"entry",
- "moduleType":"entry"
- },
- "abilities":[
- {
- "description":"$string:MainAbility_desc",
- "formsEnabled":false,
- "icon":"$media:icon",
- "label":"$string:MainAbility_label",
- "launchType":"standard",
- "name":".MainAbility",
- "orientation":"unspecified",
- "skills":[
- {
- "actions":[
- "action.system.home"
- ],
- "entities":[
- "entity.system.home"
- ]
- }
- ],
- "srcLanguage":"js",
- "srcPath":"MainAbility",
- "type":"page",
- "visible":true
- }
- ],
- "js":[
- {
- "name":".MainAbility",
- "pages":[
- "pages/index/index"
- ],
- "window":{
- "autoDesignWidth":false,
- "designWidth":720
- }
- }
- ]
- }
-}
\ No newline at end of file
diff --git a/storage/storagesecuritylabeljstest/entry/src/main/js/MainAbility/app.js b/storage/storagesecuritylabeljstest/entry/src/main/js/MainAbility/app.js
deleted file mode 100644
index 8c9a4fce93b5e76779bdf446c49269a5a51db98a..0000000000000000000000000000000000000000
--- a/storage/storagesecuritylabeljstest/entry/src/main/js/MainAbility/app.js
+++ /dev/null
@@ -1,26 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-import hilog from '@ohos.hilog';
-export default {
- onCreate() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'Application onCreate');
- },
- onDestroy() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'Application onDestroy');
- },
-}
-
-
-
diff --git a/storage/storagesecuritylabeljstest/entry/src/main/js/MainAbility/pages/index/index.css b/storage/storagesecuritylabeljstest/entry/src/main/js/MainAbility/pages/index/index.css
deleted file mode 100644
index a711febae0b34889547cd72fbe5f8cc3e0bd043c..0000000000000000000000000000000000000000
--- a/storage/storagesecuritylabeljstest/entry/src/main/js/MainAbility/pages/index/index.css
+++ /dev/null
@@ -1,60 +0,0 @@
-/*
- * Copyright (c) 2022 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-.container {
- flex-direction: column;
- justify-content: center;
- align-items: center;
- width: 100%;
- height: 100%;
-}
-
-.title {
- font-size: 40px;
- color: #000000;
- opacity: 0.9;
-}
-
-@media screen and (device-type: tablet) and (orientation: landscape) {
- .title {
- font-size: 100px;
- }
-}
-
-@media screen and (device-type: wearable) {
- .title {
- font-size: 28px;
- color: #FFFFFF;
- }
-}
-
-@media screen and (device-type: tv) {
- .container {
- background-image: url("/common/images/Wallpaper.png");
- background-size: cover;
- background-repeat: no-repeat;
- background-position: center;
- }
-
- .title {
- font-size: 100px;
- color: #FFFFFF;
- }
-}
-
-@media screen and (device-type: phone) and (orientation: landscape) {
- .title {
- font-size: 60px;
- }
-}
diff --git a/storage/storagesecuritylabeljstest/entry/src/main/js/MainAbility/pages/index/index.hml b/storage/storagesecuritylabeljstest/entry/src/main/js/MainAbility/pages/index/index.hml
deleted file mode 100644
index 95bd1e877b3fa9f5f4e4dc0ff608591b540d116d..0000000000000000000000000000000000000000
--- a/storage/storagesecuritylabeljstest/entry/src/main/js/MainAbility/pages/index/index.hml
+++ /dev/null
@@ -1,19 +0,0 @@
-/*
- * Copyright (c) 2022 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-
- {{ $t('strings.hello') }} {{ title }}
-
-
diff --git a/storage/storagesecuritylabeljstest/entry/src/main/js/MainAbility/pages/index/index.js b/storage/storagesecuritylabeljstest/entry/src/main/js/MainAbility/pages/index/index.js
deleted file mode 100644
index f086298302bd6362b079bf99cf40dfa1e00d85e9..0000000000000000000000000000000000000000
--- a/storage/storagesecuritylabeljstest/entry/src/main/js/MainAbility/pages/index/index.js
+++ /dev/null
@@ -1,22 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-export default {
- data: {
- title: ""
- },
- onInit() {
- this.title = this.$t('strings.world');
- }
-}
diff --git a/storage/storagesecuritylabeljstest/entry/src/main/resources/base/media/icon.png b/storage/storagesecuritylabeljstest/entry/src/main/resources/base/media/icon.png
deleted file mode 100644
index ce307a8827bd75456441ceb57d530e4c8d45d36c..0000000000000000000000000000000000000000
Binary files a/storage/storagesecuritylabeljstest/entry/src/main/resources/base/media/icon.png and /dev/null differ
diff --git a/storage/storagesecuritylabeljstest/entry/src/ohosTest/config.json b/storage/storagesecuritylabeljstest/entry/src/ohosTest/config.json
deleted file mode 100644
index 2b1f8a3a902004ac4c950586c21609d6a732b019..0000000000000000000000000000000000000000
--- a/storage/storagesecuritylabeljstest/entry/src/ohosTest/config.json
+++ /dev/null
@@ -1,69 +0,0 @@
-{
- "app":{
- "bundleName":"ohos.acts.storage.securitylabel",
- "vendor":"example",
- "version":{
- "code":1000000,
- "name":"1.0.0"
- }
- },
- "deviceConfig":{
-
- },
- "module":{
- "package":"ohos.acts.storage.securitylabel_test",
- "name":".entry_test",
- "mainAbility":".TestAbility",
- "deviceType": [
- "tablet",
- "default"
- ],
- "testRunner":{
- "name":"OpenHarmonyTestRunner",
- "srcPath":"TestRunner"
- },
- "distro":{
- "deliveryWithInstall":true,
- "installationFree":true,
- "moduleName":"entry_test",
- "moduleType":"feature"
- },
- "abilities":[
- {
- "description":"$string:TestAbility_desc",
- "formsEnabled":false,
- "icon":"$media:icon",
- "label":"$string:TestAbility_label",
- "launchType":"standard",
- "name":".TestAbility",
- "orientation":"unspecified",
- "skills":[
- {
- "actions":[
- "action.system.home"
- ],
- "entities":[
- "entity.system.home"
- ]
- }
- ],
- "srcLanguage":"js",
- "srcPath":"TestAbility",
- "type":"page",
- "visible":true
- }
- ],
- "js":[
- {
- "name":".TestAbility",
- "pages":[
- "pages/index/index"
- ],
- "window":{
- "autoDesignWidth":false,
- "designWidth":720
- }
- }
- ]
- }
-}
\ No newline at end of file
diff --git a/storage/storagesecuritylabeljstest/entry/src/ohosTest/resources/base/element/string.json b/storage/storagesecuritylabeljstest/entry/src/ohosTest/resources/base/element/string.json
deleted file mode 100644
index e177d239b04cc6ade85c481da89b6f01bcb8c444..0000000000000000000000000000000000000000
--- a/storage/storagesecuritylabeljstest/entry/src/ohosTest/resources/base/element/string.json
+++ /dev/null
@@ -1,28 +0,0 @@
-{
- "string": [
- {
- "name": "app_name",
- "value": "Storagesecuritylabeljstest"
- },
- {
- "name": "mainability_description",
- "value": "JS_Phone_Empty Feature Ability"
- },
- {
- "name": "MainAbility_desc",
- "value": "description"
- },
- {
- "name": "MainAbility_label",
- "value": "label"
- },
- {
- "name": "TestAbility_desc",
- "value": "description"
- },
- {
- "name": "TestAbility_label",
- "value": "label"
- }
- ]
-}
\ No newline at end of file
diff --git a/storage/storagesecuritylabeljstest/entry/src/ohosTest/resources/base/media/icon.png b/storage/storagesecuritylabeljstest/entry/src/ohosTest/resources/base/media/icon.png
deleted file mode 100644
index ce307a8827bd75456441ceb57d530e4c8d45d36c..0000000000000000000000000000000000000000
Binary files a/storage/storagesecuritylabeljstest/entry/src/ohosTest/resources/base/media/icon.png and /dev/null differ
diff --git a/storage/storagesecuritylabeljstest/hvigor/hvigor-config.json5 b/storage/storagesecuritylabeljstest/hvigor/hvigor-config.json5
deleted file mode 100644
index d1ed6c3c0cb895265a376515209a0575aeb7d898..0000000000000000000000000000000000000000
--- a/storage/storagesecuritylabeljstest/hvigor/hvigor-config.json5
+++ /dev/null
@@ -1,20 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-{
- "hvigorVersion": "2.0.0",
- "dependencies": {
- "@ohos/hvigor-ohos-plugin": "2.0.0"
- }
-}
diff --git a/storage/storagesecuritylabeljstest/hvigor/hvigor-wrapper.js b/storage/storagesecuritylabeljstest/hvigor/hvigor-wrapper.js
deleted file mode 100644
index 2507619ca768432ff3fb806441f29eff47a4c4f0..0000000000000000000000000000000000000000
--- a/storage/storagesecuritylabeljstest/hvigor/hvigor-wrapper.js
+++ /dev/null
@@ -1,16 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-"use strict";var e=require("fs"),t=require("path"),n=require("os"),r=require("crypto"),u=require("child_process"),o=require("constants"),i=require("stream"),s=require("util"),c=require("assert"),a=require("tty"),l=require("zlib"),f=require("net");function d(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var D=d(e),p=d(t),E=d(n),m=d(r),h=d(u),y=d(o),C=d(i),F=d(s),g=d(c),A=d(a),v=d(l),S=d(f),w="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{},O={},b={},_={},B=w&&w.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(_,"__esModule",{value:!0}),_.isMac=_.isLinux=_.isWindows=void 0;const P=B(E.default),k="Windows_NT",x="Linux",N="Darwin";_.isWindows=function(){return P.default.type()===k},_.isLinux=function(){return P.default.type()===x},_.isMac=function(){return P.default.type()===N};var I={},T=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),R=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),M=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)"default"!==n&&Object.prototype.hasOwnProperty.call(e,n)&&T(t,e,n);return R(t,e),t};Object.defineProperty(I,"__esModule",{value:!0}),I.hash=void 0;const L=M(m.default);I.hash=function(e,t="md5"){return L.createHash(t).update(e,"utf-8").digest("hex")},function(e){var t=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),n=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),r=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var r={};if(null!=e)for(var u in e)"default"!==u&&Object.prototype.hasOwnProperty.call(e,u)&&t(r,e,u);return n(r,e),r};Object.defineProperty(e,"__esModule",{value:!0}),e.HVIGOR_BOOT_JS_FILE_PATH=e.HVIGOR_PROJECT_DEPENDENCY_PACKAGE_JSON_PATH=e.HVIGOR_PROJECT_DEPENDENCIES_HOME=e.HVIGOR_PROJECT_WRAPPER_HOME=e.HVIGOR_PROJECT_NAME=e.HVIGOR_PROJECT_ROOT_DIR=e.HVIGOR_PROJECT_CACHES_HOME=e.HVIGOR_PNPM_STORE_PATH=e.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH=e.HVIGOR_WRAPPER_TOOLS_HOME=e.HVIGOR_USER_HOME=e.DEFAULT_PACKAGE_JSON=e.DEFAULT_HVIGOR_CONFIG_JSON_FILE_NAME=e.PNPM=e.HVIGOR=e.NPM_TOOL=e.PNPM_TOOL=e.HVIGOR_ENGINE_PACKAGE_NAME=void 0;const u=r(p.default),o=r(E.default),i=_,s=I;e.HVIGOR_ENGINE_PACKAGE_NAME="@ohos/hvigor",e.PNPM_TOOL=(0,i.isWindows)()?"pnpm.cmd":"pnpm",e.NPM_TOOL=(0,i.isWindows)()?"npm.cmd":"npm",e.HVIGOR="hvigor",e.PNPM="pnpm",e.DEFAULT_HVIGOR_CONFIG_JSON_FILE_NAME="hvigor-config.json5",e.DEFAULT_PACKAGE_JSON="package.json",e.HVIGOR_USER_HOME=u.resolve(o.homedir(),".hvigor"),e.HVIGOR_WRAPPER_TOOLS_HOME=u.resolve(e.HVIGOR_USER_HOME,"wrapper","tools"),e.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH=u.resolve(e.HVIGOR_WRAPPER_TOOLS_HOME,"node_modules",".bin",e.PNPM_TOOL),e.HVIGOR_PNPM_STORE_PATH=u.resolve(e.HVIGOR_USER_HOME,"caches"),e.HVIGOR_PROJECT_CACHES_HOME=u.resolve(e.HVIGOR_USER_HOME,"project_caches"),e.HVIGOR_PROJECT_ROOT_DIR=process.cwd(),e.HVIGOR_PROJECT_NAME=u.basename((0,s.hash)(e.HVIGOR_PROJECT_ROOT_DIR)),e.HVIGOR_PROJECT_WRAPPER_HOME=u.resolve(e.HVIGOR_PROJECT_ROOT_DIR,e.HVIGOR),e.HVIGOR_PROJECT_DEPENDENCIES_HOME=u.resolve(e.HVIGOR_PROJECT_CACHES_HOME,e.HVIGOR_PROJECT_NAME,"workspace"),e.HVIGOR_PROJECT_DEPENDENCY_PACKAGE_JSON_PATH=u.resolve(e.HVIGOR_PROJECT_DEPENDENCIES_HOME,e.DEFAULT_PACKAGE_JSON),e.HVIGOR_BOOT_JS_FILE_PATH=u.resolve(e.HVIGOR_PROJECT_DEPENDENCIES_HOME,"node_modules","@ohos","hvigor","bin","hvigor.js")}(b);var j={},$={};Object.defineProperty($,"__esModule",{value:!0}),$.logInfoPrintConsole=$.logErrorAndExit=void 0,$.logErrorAndExit=function(e){e instanceof Error?console.error(e.message):console.error(e),process.exit(-1)},$.logInfoPrintConsole=function(e){console.log(e)};var H=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),J=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),G=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)"default"!==n&&Object.prototype.hasOwnProperty.call(e,n)&&H(t,e,n);return J(t,e),t},V=w&&w.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(j,"__esModule",{value:!0}),j.isFileExists=j.offlinePluginConversion=j.executeCommand=j.getNpmPath=j.hasNpmPackInPaths=void 0;const U=h.default,W=G(p.default),z=b,K=$,q=V(D.default);j.hasNpmPackInPaths=function(e,t){try{return require.resolve(e,{paths:[...t]}),!0}catch(e){return!1}},j.getNpmPath=function(){const e=process.execPath;return W.join(W.dirname(e),z.NPM_TOOL)},j.executeCommand=function(e,t,n){0!==(0,U.spawnSync)(e,t,n).status&&(0,K.logErrorAndExit)(`Error: ${e} ${t} execute failed.See above for details.`)},j.offlinePluginConversion=function(e,t){return t.startsWith("file:")||t.endsWith(".tgz")?W.resolve(e,z.HVIGOR,t.replace("file:","")):t},j.isFileExists=function(e){return q.default.existsSync(e)&&q.default.statSync(e).isFile()},function(e){var t=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),n=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),r=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var r={};if(null!=e)for(var u in e)"default"!==u&&Object.prototype.hasOwnProperty.call(e,u)&&t(r,e,u);return n(r,e),r},u=w&&w.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(e,"__esModule",{value:!0}),e.executeInstallPnpm=e.isPnpmAvailable=e.environmentHandler=e.checkNpmConifg=e.PNPM_VERSION=void 0;const o=r(D.default),i=b,s=j,c=r(p.default),a=$,l=h.default,f=u(E.default);e.PNPM_VERSION="7.30.0",e.checkNpmConifg=function(){const e=c.resolve(i.HVIGOR_PROJECT_ROOT_DIR,".npmrc"),t=c.resolve(f.default.homedir(),".npmrc");if((0,s.isFileExists)(e)||(0,s.isFileExists)(t))return;const n=(0,s.getNpmPath)(),r=(0,l.spawnSync)(n,["config","get","prefix"],{cwd:i.HVIGOR_PROJECT_ROOT_DIR});if(0!==r.status||!r.stdout)return void(0,a.logErrorAndExit)("Error: The hvigor depends on the npmrc file. Configure the npmrc file first.");const u=c.resolve(`${r.stdout}`.replace(/[\r\n]/gi,""),".npmrc");(0,s.isFileExists)(u)||(0,a.logErrorAndExit)("Error: The hvigor depends on the npmrc file. Configure the npmrc file first.")},e.environmentHandler=function(){process.env["npm_config_update-notifier"]="false"},e.isPnpmAvailable=function(){return!!o.existsSync(i.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH)&&(0,s.hasNpmPackInPaths)("pnpm",[i.HVIGOR_WRAPPER_TOOLS_HOME])},e.executeInstallPnpm=function(){(0,a.logInfoPrintConsole)(`Installing pnpm@${e.PNPM_VERSION}...`);const t=(0,s.getNpmPath)();!function(){const t=c.resolve(i.HVIGOR_WRAPPER_TOOLS_HOME,i.DEFAULT_PACKAGE_JSON);try{o.existsSync(i.HVIGOR_WRAPPER_TOOLS_HOME)||o.mkdirSync(i.HVIGOR_WRAPPER_TOOLS_HOME,{recursive:!0});const n={dependencies:{}};n.dependencies[i.PNPM]=e.PNPM_VERSION,o.writeFileSync(t,JSON.stringify(n))}catch(e){(0,a.logErrorAndExit)(`Error: EPERM: operation not permitted,create ${t} failed.`)}}(),(0,s.executeCommand)(t,["install","pnpm"],{cwd:i.HVIGOR_WRAPPER_TOOLS_HOME,stdio:["inherit","inherit","inherit"],env:process.env}),(0,a.logInfoPrintConsole)("Pnpm install success.")}}(O);var Y={},X={},Z={},Q={};Object.defineProperty(Q,"__esModule",{value:!0}),Q.Unicode=void 0;class ee{}Q.Unicode=ee,ee.Space_Separator=/[\u1680\u2000-\u200A\u202F\u205F\u3000]/,ee.ID_Start=/[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u05D0-\u05EA\u05F0-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u0860-\u086A\u08A0-\u08B4\u08B6-\u08BD\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u09FC\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0AF9\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58-\u0C5A\u0C60\u0C61\u0C80\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D54-\u0D56\u0D5F-\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1711\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1877\u1880-\u1884\u1887-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1C80-\u1C88\u1CE9-\u1CEC\u1CEE-\u1CF1\u1CF5\u1CF6\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005-\u3007\u3021-\u3029\u3031-\u3035\u3038-\u303C\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312E\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FEA\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6EF\uA717-\uA71F\uA722-\uA788\uA78B-\uA7AE\uA7B0-\uA7B7\uA7F7-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA8FD\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uA9E0-\uA9E4\uA9E6-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB65\uAB70-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD40-\uDD74\uDE80-\uDE9C\uDEA0-\uDED0\uDF00-\uDF1F\uDF2D-\uDF4A\uDF50-\uDF75\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDCB0-\uDCD3\uDCD8-\uDCFB\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDCE0-\uDCF2\uDCF4\uDCF5\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00\uDE10-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE4\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48\uDC80-\uDCB2\uDCC0-\uDCF2]|\uD804[\uDC03-\uDC37\uDC83-\uDCAF\uDCD0-\uDCE8\uDD03-\uDD26\uDD50-\uDD72\uDD76\uDD83-\uDDB2\uDDC1-\uDDC4\uDDDA\uDDDC\uDE00-\uDE11\uDE13-\uDE2B\uDE80-\uDE86\uDE88\uDE8A-\uDE8D\uDE8F-\uDE9D\uDE9F-\uDEA8\uDEB0-\uDEDE\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3D\uDF50\uDF5D-\uDF61]|\uD805[\uDC00-\uDC34\uDC47-\uDC4A\uDC80-\uDCAF\uDCC4\uDCC5\uDCC7\uDD80-\uDDAE\uDDD8-\uDDDB\uDE00-\uDE2F\uDE44\uDE80-\uDEAA\uDF00-\uDF19]|\uD806[\uDCA0-\uDCDF\uDCFF\uDE00\uDE0B-\uDE32\uDE3A\uDE50\uDE5C-\uDE83\uDE86-\uDE89\uDEC0-\uDEF8]|\uD807[\uDC00-\uDC08\uDC0A-\uDC2E\uDC40\uDC72-\uDC8F\uDD00-\uDD06\uDD08\uDD09\uDD0B-\uDD30\uDD46]|\uD808[\uDC00-\uDF99]|\uD809[\uDC00-\uDC6E\uDC80-\uDD43]|[\uD80C\uD81C-\uD820\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD811[\uDC00-\uDE46]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDED0-\uDEED\uDF00-\uDF2F\uDF40-\uDF43\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50\uDF93-\uDF9F\uDFE0\uDFE1]|\uD821[\uDC00-\uDFEC]|\uD822[\uDC00-\uDEF2]|\uD82C[\uDC00-\uDD1E\uDD70-\uDEFB]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB]|\uD83A[\uDC00-\uDCC4\uDD00-\uDD43]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0]|\uD87E[\uDC00-\uDE1D]/,ee.ID_Continue=/[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0300-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u0483-\u0487\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u0591-\u05BD\u05BF\u05C1\u05C2\u05C4\u05C5\u05C7\u05D0-\u05EA\u05F0-\u05F2\u0610-\u061A\u0620-\u0669\u066E-\u06D3\u06D5-\u06DC\u06DF-\u06E8\u06EA-\u06FC\u06FF\u0710-\u074A\u074D-\u07B1\u07C0-\u07F5\u07FA\u0800-\u082D\u0840-\u085B\u0860-\u086A\u08A0-\u08B4\u08B6-\u08BD\u08D4-\u08E1\u08E3-\u0963\u0966-\u096F\u0971-\u0983\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BC-\u09C4\u09C7\u09C8\u09CB-\u09CE\u09D7\u09DC\u09DD\u09DF-\u09E3\u09E6-\u09F1\u09FC\u0A01-\u0A03\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A3C\u0A3E-\u0A42\u0A47\u0A48\u0A4B-\u0A4D\u0A51\u0A59-\u0A5C\u0A5E\u0A66-\u0A75\u0A81-\u0A83\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABC-\u0AC5\u0AC7-\u0AC9\u0ACB-\u0ACD\u0AD0\u0AE0-\u0AE3\u0AE6-\u0AEF\u0AF9-\u0AFF\u0B01-\u0B03\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3C-\u0B44\u0B47\u0B48\u0B4B-\u0B4D\u0B56\u0B57\u0B5C\u0B5D\u0B5F-\u0B63\u0B66-\u0B6F\u0B71\u0B82\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BBE-\u0BC2\u0BC6-\u0BC8\u0BCA-\u0BCD\u0BD0\u0BD7\u0BE6-\u0BEF\u0C00-\u0C03\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D-\u0C44\u0C46-\u0C48\u0C4A-\u0C4D\u0C55\u0C56\u0C58-\u0C5A\u0C60-\u0C63\u0C66-\u0C6F\u0C80-\u0C83\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBC-\u0CC4\u0CC6-\u0CC8\u0CCA-\u0CCD\u0CD5\u0CD6\u0CDE\u0CE0-\u0CE3\u0CE6-\u0CEF\u0CF1\u0CF2\u0D00-\u0D03\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D44\u0D46-\u0D48\u0D4A-\u0D4E\u0D54-\u0D57\u0D5F-\u0D63\u0D66-\u0D6F\u0D7A-\u0D7F\u0D82\u0D83\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0DCA\u0DCF-\u0DD4\u0DD6\u0DD8-\u0DDF\u0DE6-\u0DEF\u0DF2\u0DF3\u0E01-\u0E3A\u0E40-\u0E4E\u0E50-\u0E59\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB9\u0EBB-\u0EBD\u0EC0-\u0EC4\u0EC6\u0EC8-\u0ECD\u0ED0-\u0ED9\u0EDC-\u0EDF\u0F00\u0F18\u0F19\u0F20-\u0F29\u0F35\u0F37\u0F39\u0F3E-\u0F47\u0F49-\u0F6C\u0F71-\u0F84\u0F86-\u0F97\u0F99-\u0FBC\u0FC6\u1000-\u1049\u1050-\u109D\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u135D-\u135F\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1714\u1720-\u1734\u1740-\u1753\u1760-\u176C\u176E-\u1770\u1772\u1773\u1780-\u17D3\u17D7\u17DC\u17DD\u17E0-\u17E9\u180B-\u180D\u1810-\u1819\u1820-\u1877\u1880-\u18AA\u18B0-\u18F5\u1900-\u191E\u1920-\u192B\u1930-\u193B\u1946-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u19D0-\u19D9\u1A00-\u1A1B\u1A20-\u1A5E\u1A60-\u1A7C\u1A7F-\u1A89\u1A90-\u1A99\u1AA7\u1AB0-\u1ABD\u1B00-\u1B4B\u1B50-\u1B59\u1B6B-\u1B73\u1B80-\u1BF3\u1C00-\u1C37\u1C40-\u1C49\u1C4D-\u1C7D\u1C80-\u1C88\u1CD0-\u1CD2\u1CD4-\u1CF9\u1D00-\u1DF9\u1DFB-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u203F\u2040\u2054\u2071\u207F\u2090-\u209C\u20D0-\u20DC\u20E1\u20E5-\u20F0\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D7F-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2DE0-\u2DFF\u2E2F\u3005-\u3007\u3021-\u302F\u3031-\u3035\u3038-\u303C\u3041-\u3096\u3099\u309A\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312E\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FEA\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA62B\uA640-\uA66F\uA674-\uA67D\uA67F-\uA6F1\uA717-\uA71F\uA722-\uA788\uA78B-\uA7AE\uA7B0-\uA7B7\uA7F7-\uA827\uA840-\uA873\uA880-\uA8C5\uA8D0-\uA8D9\uA8E0-\uA8F7\uA8FB\uA8FD\uA900-\uA92D\uA930-\uA953\uA960-\uA97C\uA980-\uA9C0\uA9CF-\uA9D9\uA9E0-\uA9FE\uAA00-\uAA36\uAA40-\uAA4D\uAA50-\uAA59\uAA60-\uAA76\uAA7A-\uAAC2\uAADB-\uAADD\uAAE0-\uAAEF\uAAF2-\uAAF6\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB65\uAB70-\uABEA\uABEC\uABED\uABF0-\uABF9\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE00-\uFE0F\uFE20-\uFE2F\uFE33\uFE34\uFE4D-\uFE4F\uFE70-\uFE74\uFE76-\uFEFC\uFF10-\uFF19\uFF21-\uFF3A\uFF3F\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD40-\uDD74\uDDFD\uDE80-\uDE9C\uDEA0-\uDED0\uDEE0\uDF00-\uDF1F\uDF2D-\uDF4A\uDF50-\uDF7A\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDCA0-\uDCA9\uDCB0-\uDCD3\uDCD8-\uDCFB\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDCE0-\uDCF2\uDCF4\uDCF5\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00-\uDE03\uDE05\uDE06\uDE0C-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE38-\uDE3A\uDE3F\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE6\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48\uDC80-\uDCB2\uDCC0-\uDCF2]|\uD804[\uDC00-\uDC46\uDC66-\uDC6F\uDC7F-\uDCBA\uDCD0-\uDCE8\uDCF0-\uDCF9\uDD00-\uDD34\uDD36-\uDD3F\uDD50-\uDD73\uDD76\uDD80-\uDDC4\uDDCA-\uDDCC\uDDD0-\uDDDA\uDDDC\uDE00-\uDE11\uDE13-\uDE37\uDE3E\uDE80-\uDE86\uDE88\uDE8A-\uDE8D\uDE8F-\uDE9D\uDE9F-\uDEA8\uDEB0-\uDEEA\uDEF0-\uDEF9\uDF00-\uDF03\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3C-\uDF44\uDF47\uDF48\uDF4B-\uDF4D\uDF50\uDF57\uDF5D-\uDF63\uDF66-\uDF6C\uDF70-\uDF74]|\uD805[\uDC00-\uDC4A\uDC50-\uDC59\uDC80-\uDCC5\uDCC7\uDCD0-\uDCD9\uDD80-\uDDB5\uDDB8-\uDDC0\uDDD8-\uDDDD\uDE00-\uDE40\uDE44\uDE50-\uDE59\uDE80-\uDEB7\uDEC0-\uDEC9\uDF00-\uDF19\uDF1D-\uDF2B\uDF30-\uDF39]|\uD806[\uDCA0-\uDCE9\uDCFF\uDE00-\uDE3E\uDE47\uDE50-\uDE83\uDE86-\uDE99\uDEC0-\uDEF8]|\uD807[\uDC00-\uDC08\uDC0A-\uDC36\uDC38-\uDC40\uDC50-\uDC59\uDC72-\uDC8F\uDC92-\uDCA7\uDCA9-\uDCB6\uDD00-\uDD06\uDD08\uDD09\uDD0B-\uDD36\uDD3A\uDD3C\uDD3D\uDD3F-\uDD47\uDD50-\uDD59]|\uD808[\uDC00-\uDF99]|\uD809[\uDC00-\uDC6E\uDC80-\uDD43]|[\uD80C\uD81C-\uD820\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD811[\uDC00-\uDE46]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDE60-\uDE69\uDED0-\uDEED\uDEF0-\uDEF4\uDF00-\uDF36\uDF40-\uDF43\uDF50-\uDF59\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50-\uDF7E\uDF8F-\uDF9F\uDFE0\uDFE1]|\uD821[\uDC00-\uDFEC]|\uD822[\uDC00-\uDEF2]|\uD82C[\uDC00-\uDD1E\uDD70-\uDEFB]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99\uDC9D\uDC9E]|\uD834[\uDD65-\uDD69\uDD6D-\uDD72\uDD7B-\uDD82\uDD85-\uDD8B\uDDAA-\uDDAD\uDE42-\uDE44]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB\uDFCE-\uDFFF]|\uD836[\uDE00-\uDE36\uDE3B-\uDE6C\uDE75\uDE84\uDE9B-\uDE9F\uDEA1-\uDEAF]|\uD838[\uDC00-\uDC06\uDC08-\uDC18\uDC1B-\uDC21\uDC23\uDC24\uDC26-\uDC2A]|\uD83A[\uDC00-\uDCC4\uDCD0-\uDCD6\uDD00-\uDD4A\uDD50-\uDD59]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0]|\uD87E[\uDC00-\uDE1D]|\uDB40[\uDD00-\uDDEF]/,Object.defineProperty(Z,"__esModule",{value:!0}),Z.JudgeUtil=void 0;const te=Q;Z.JudgeUtil=class{static isIgnoreChar(e){return"string"==typeof e&&("\t"===e||"\v"===e||"\f"===e||" "===e||" "===e||"\ufeff"===e||"\n"===e||"\r"===e||"\u2028"===e||"\u2029"===e)}static isSpaceSeparator(e){return"string"==typeof e&&te.Unicode.Space_Separator.test(e)}static isIdStartChar(e){return"string"==typeof e&&(e>="a"&&e<="z"||e>="A"&&e<="Z"||"$"===e||"_"===e||te.Unicode.ID_Start.test(e))}static isIdContinueChar(e){return"string"==typeof e&&(e>="a"&&e<="z"||e>="A"&&e<="Z"||e>="0"&&e<="9"||"$"===e||"_"===e||""===e||""===e||te.Unicode.ID_Continue.test(e))}static isDigitWithoutZero(e){return/[1-9]/.test(e)}static isDigit(e){return"string"==typeof e&&/[0-9]/.test(e)}static isHexDigit(e){return"string"==typeof e&&/[0-9A-Fa-f]/.test(e)}};var ne={},re={fromCallback:function(e){return Object.defineProperty((function(...t){if("function"!=typeof t[t.length-1])return new Promise(((n,r)=>{e.call(this,...t,((e,t)=>null!=e?r(e):n(t)))}));e.apply(this,t)}),"name",{value:e.name})},fromPromise:function(e){return Object.defineProperty((function(...t){const n=t[t.length-1];if("function"!=typeof n)return e.apply(this,t);e.apply(this,t.slice(0,-1)).then((e=>n(null,e)),n)}),"name",{value:e.name})}},ue=y.default,oe=process.cwd,ie=null,se=process.env.GRACEFUL_FS_PLATFORM||process.platform;process.cwd=function(){return ie||(ie=oe.call(process)),ie};try{process.cwd()}catch(e){}if("function"==typeof process.chdir){var ce=process.chdir;process.chdir=function(e){ie=null,ce.call(process,e)},Object.setPrototypeOf&&Object.setPrototypeOf(process.chdir,ce)}var ae=function(e){ue.hasOwnProperty("O_SYMLINK")&&process.version.match(/^v0\.6\.[0-2]|^v0\.5\./)&&function(e){e.lchmod=function(t,n,r){e.open(t,ue.O_WRONLY|ue.O_SYMLINK,n,(function(t,u){t?r&&r(t):e.fchmod(u,n,(function(t){e.close(u,(function(e){r&&r(t||e)}))}))}))},e.lchmodSync=function(t,n){var r,u=e.openSync(t,ue.O_WRONLY|ue.O_SYMLINK,n),o=!0;try{r=e.fchmodSync(u,n),o=!1}finally{if(o)try{e.closeSync(u)}catch(e){}else e.closeSync(u)}return r}}(e);e.lutimes||function(e){ue.hasOwnProperty("O_SYMLINK")&&e.futimes?(e.lutimes=function(t,n,r,u){e.open(t,ue.O_SYMLINK,(function(t,o){t?u&&u(t):e.futimes(o,n,r,(function(t){e.close(o,(function(e){u&&u(t||e)}))}))}))},e.lutimesSync=function(t,n,r){var u,o=e.openSync(t,ue.O_SYMLINK),i=!0;try{u=e.futimesSync(o,n,r),i=!1}finally{if(i)try{e.closeSync(o)}catch(e){}else e.closeSync(o)}return u}):e.futimes&&(e.lutimes=function(e,t,n,r){r&&process.nextTick(r)},e.lutimesSync=function(){})}(e);e.chown=r(e.chown),e.fchown=r(e.fchown),e.lchown=r(e.lchown),e.chmod=t(e.chmod),e.fchmod=t(e.fchmod),e.lchmod=t(e.lchmod),e.chownSync=u(e.chownSync),e.fchownSync=u(e.fchownSync),e.lchownSync=u(e.lchownSync),e.chmodSync=n(e.chmodSync),e.fchmodSync=n(e.fchmodSync),e.lchmodSync=n(e.lchmodSync),e.stat=o(e.stat),e.fstat=o(e.fstat),e.lstat=o(e.lstat),e.statSync=i(e.statSync),e.fstatSync=i(e.fstatSync),e.lstatSync=i(e.lstatSync),e.chmod&&!e.lchmod&&(e.lchmod=function(e,t,n){n&&process.nextTick(n)},e.lchmodSync=function(){});e.chown&&!e.lchown&&(e.lchown=function(e,t,n,r){r&&process.nextTick(r)},e.lchownSync=function(){});"win32"===se&&(e.rename="function"!=typeof e.rename?e.rename:function(t){function n(n,r,u){var o=Date.now(),i=0;t(n,r,(function s(c){if(c&&("EACCES"===c.code||"EPERM"===c.code||"EBUSY"===c.code)&&Date.now()-o<6e4)return setTimeout((function(){e.stat(r,(function(e,o){e&&"ENOENT"===e.code?t(n,r,s):u(c)}))}),i),void(i<100&&(i+=10));u&&u(c)}))}return Object.setPrototypeOf&&Object.setPrototypeOf(n,t),n}(e.rename));function t(t){return t?function(n,r,u){return t.call(e,n,r,(function(e){s(e)&&(e=null),u&&u.apply(this,arguments)}))}:t}function n(t){return t?function(n,r){try{return t.call(e,n,r)}catch(e){if(!s(e))throw e}}:t}function r(t){return t?function(n,r,u,o){return t.call(e,n,r,u,(function(e){s(e)&&(e=null),o&&o.apply(this,arguments)}))}:t}function u(t){return t?function(n,r,u){try{return t.call(e,n,r,u)}catch(e){if(!s(e))throw e}}:t}function o(t){return t?function(n,r,u){function o(e,t){t&&(t.uid<0&&(t.uid+=4294967296),t.gid<0&&(t.gid+=4294967296)),u&&u.apply(this,arguments)}return"function"==typeof r&&(u=r,r=null),r?t.call(e,n,r,o):t.call(e,n,o)}:t}function i(t){return t?function(n,r){var u=r?t.call(e,n,r):t.call(e,n);return u&&(u.uid<0&&(u.uid+=4294967296),u.gid<0&&(u.gid+=4294967296)),u}:t}function s(e){return!e||("ENOSYS"===e.code||!(process.getuid&&0===process.getuid()||"EINVAL"!==e.code&&"EPERM"!==e.code))}e.read="function"!=typeof e.read?e.read:function(t){function n(n,r,u,o,i,s){var c;if(s&&"function"==typeof s){var a=0;c=function(l,f,d){if(l&&"EAGAIN"===l.code&&a<10)return a++,t.call(e,n,r,u,o,i,c);s.apply(this,arguments)}}return t.call(e,n,r,u,o,i,c)}return Object.setPrototypeOf&&Object.setPrototypeOf(n,t),n}(e.read),e.readSync="function"!=typeof e.readSync?e.readSync:(c=e.readSync,function(t,n,r,u,o){for(var i=0;;)try{return c.call(e,t,n,r,u,o)}catch(e){if("EAGAIN"===e.code&&i<10){i++;continue}throw e}});var c};var le=C.default.Stream,fe=function(e){return{ReadStream:function t(n,r){if(!(this instanceof t))return new t(n,r);le.call(this);var u=this;this.path=n,this.fd=null,this.readable=!0,this.paused=!1,this.flags="r",this.mode=438,this.bufferSize=65536,r=r||{};for(var o=Object.keys(r),i=0,s=o.length;ithis.end)throw new Error("start must be <= end");this.pos=this.start}if(null!==this.fd)return void process.nextTick((function(){u._read()}));e.open(this.path,this.flags,this.mode,(function(e,t){if(e)return u.emit("error",e),void(u.readable=!1);u.fd=t,u.emit("open",t),u._read()}))},WriteStream:function t(n,r){if(!(this instanceof t))return new t(n,r);le.call(this),this.path=n,this.fd=null,this.writable=!0,this.flags="w",this.encoding="binary",this.mode=438,this.bytesWritten=0,r=r||{};for(var u=Object.keys(r),o=0,i=u.length;o= zero");this.pos=this.start}this.busy=!1,this._queue=[],null===this.fd&&(this._open=e.open,this._queue.push([this._open,this.path,this.flags,this.mode,void 0]),this.flush())}}};var de=function(e){if(null===e||"object"!=typeof e)return e;if(e instanceof Object)var t={__proto__:De(e)};else t=Object.create(null);return Object.getOwnPropertyNames(e).forEach((function(n){Object.defineProperty(t,n,Object.getOwnPropertyDescriptor(e,n))})),t},De=Object.getPrototypeOf||function(e){return e.__proto__};var pe,Ee,me=D.default,he=ae,ye=fe,Ce=de,Fe=F.default;function ge(e,t){Object.defineProperty(e,pe,{get:function(){return t}})}"function"==typeof Symbol&&"function"==typeof Symbol.for?(pe=Symbol.for("graceful-fs.queue"),Ee=Symbol.for("graceful-fs.previous")):(pe="___graceful-fs.queue",Ee="___graceful-fs.previous");var Ae=function(){};if(Fe.debuglog?Ae=Fe.debuglog("gfs4"):/\bgfs4\b/i.test(process.env.NODE_DEBUG||"")&&(Ae=function(){var e=Fe.format.apply(Fe,arguments);e="GFS4: "+e.split(/\n/).join("\nGFS4: "),console.error(e)}),!me[pe]){var ve=w[pe]||[];ge(me,ve),me.close=function(e){function t(t,n){return e.call(me,t,(function(e){e||_e(),"function"==typeof n&&n.apply(this,arguments)}))}return Object.defineProperty(t,Ee,{value:e}),t}(me.close),me.closeSync=function(e){function t(t){e.apply(me,arguments),_e()}return Object.defineProperty(t,Ee,{value:e}),t}(me.closeSync),/\bgfs4\b/i.test(process.env.NODE_DEBUG||"")&&process.on("exit",(function(){Ae(me[pe]),g.default.equal(me[pe].length,0)}))}w[pe]||ge(w,me[pe]);var Se,we=Oe(Ce(me));function Oe(e){he(e),e.gracefulify=Oe,e.createReadStream=function(t,n){return new e.ReadStream(t,n)},e.createWriteStream=function(t,n){return new e.WriteStream(t,n)};var t=e.readFile;e.readFile=function(e,n,r){"function"==typeof n&&(r=n,n=null);return function e(n,r,u,o){return t(n,r,(function(t){!t||"EMFILE"!==t.code&&"ENFILE"!==t.code?"function"==typeof u&&u.apply(this,arguments):be([e,[n,r,u],t,o||Date.now(),Date.now()])}))}(e,n,r)};var n=e.writeFile;e.writeFile=function(e,t,r,u){"function"==typeof r&&(u=r,r=null);return function e(t,r,u,o,i){return n(t,r,u,(function(n){!n||"EMFILE"!==n.code&&"ENFILE"!==n.code?"function"==typeof o&&o.apply(this,arguments):be([e,[t,r,u,o],n,i||Date.now(),Date.now()])}))}(e,t,r,u)};var r=e.appendFile;r&&(e.appendFile=function(e,t,n,u){"function"==typeof n&&(u=n,n=null);return function e(t,n,u,o,i){return r(t,n,u,(function(r){!r||"EMFILE"!==r.code&&"ENFILE"!==r.code?"function"==typeof o&&o.apply(this,arguments):be([e,[t,n,u,o],r,i||Date.now(),Date.now()])}))}(e,t,n,u)});var u=e.copyFile;u&&(e.copyFile=function(e,t,n,r){"function"==typeof n&&(r=n,n=0);return function e(t,n,r,o,i){return u(t,n,r,(function(u){!u||"EMFILE"!==u.code&&"ENFILE"!==u.code?"function"==typeof o&&o.apply(this,arguments):be([e,[t,n,r,o],u,i||Date.now(),Date.now()])}))}(e,t,n,r)});var o=e.readdir;e.readdir=function(e,t,n){"function"==typeof t&&(n=t,t=null);var r=i.test(process.version)?function(e,t,n,r){return o(e,u(e,t,n,r))}:function(e,t,n,r){return o(e,t,u(e,t,n,r))};return r(e,t,n);function u(e,t,n,u){return function(o,i){!o||"EMFILE"!==o.code&&"ENFILE"!==o.code?(i&&i.sort&&i.sort(),"function"==typeof n&&n.call(this,o,i)):be([r,[e,t,n],o,u||Date.now(),Date.now()])}}};var i=/^v[0-5]\./;if("v0.8"===process.version.substr(0,4)){var s=ye(e);d=s.ReadStream,D=s.WriteStream}var c=e.ReadStream;c&&(d.prototype=Object.create(c.prototype),d.prototype.open=function(){var e=this;E(e.path,e.flags,e.mode,(function(t,n){t?(e.autoClose&&e.destroy(),e.emit("error",t)):(e.fd=n,e.emit("open",n),e.read())}))});var a=e.WriteStream;a&&(D.prototype=Object.create(a.prototype),D.prototype.open=function(){var e=this;E(e.path,e.flags,e.mode,(function(t,n){t?(e.destroy(),e.emit("error",t)):(e.fd=n,e.emit("open",n))}))}),Object.defineProperty(e,"ReadStream",{get:function(){return d},set:function(e){d=e},enumerable:!0,configurable:!0}),Object.defineProperty(e,"WriteStream",{get:function(){return D},set:function(e){D=e},enumerable:!0,configurable:!0});var l=d;Object.defineProperty(e,"FileReadStream",{get:function(){return l},set:function(e){l=e},enumerable:!0,configurable:!0});var f=D;function d(e,t){return this instanceof d?(c.apply(this,arguments),this):d.apply(Object.create(d.prototype),arguments)}function D(e,t){return this instanceof D?(a.apply(this,arguments),this):D.apply(Object.create(D.prototype),arguments)}Object.defineProperty(e,"FileWriteStream",{get:function(){return f},set:function(e){f=e},enumerable:!0,configurable:!0});var p=e.open;function E(e,t,n,r){return"function"==typeof n&&(r=n,n=null),function e(t,n,r,u,o){return p(t,n,r,(function(i,s){!i||"EMFILE"!==i.code&&"ENFILE"!==i.code?"function"==typeof u&&u.apply(this,arguments):be([e,[t,n,r,u],i,o||Date.now(),Date.now()])}))}(e,t,n,r)}return e.open=E,e}function be(e){Ae("ENQUEUE",e[0].name,e[1]),me[pe].push(e),Be()}function _e(){for(var e=Date.now(),t=0;t2&&(me[pe][t][3]=e,me[pe][t][4]=e);Be()}function Be(){if(clearTimeout(Se),Se=void 0,0!==me[pe].length){var e=me[pe].shift(),t=e[0],n=e[1],r=e[2],u=e[3],o=e[4];if(void 0===u)Ae("RETRY",t.name,n),t.apply(null,n);else if(Date.now()-u>=6e4){Ae("TIMEOUT",t.name,n);var i=n.pop();"function"==typeof i&&i.call(null,r)}else{var s=Date.now()-o,c=Math.max(o-u,1);s>=Math.min(1.2*c,100)?(Ae("RETRY",t.name,n),t.apply(null,n.concat([u]))):me[pe].push(e)}void 0===Se&&(Se=setTimeout(Be,0))}}process.env.TEST_GRACEFUL_FS_GLOBAL_PATCH&&!me.__patched&&(we=Oe(me),me.__patched=!0),function(e){const t=re.fromCallback,n=we,r=["access","appendFile","chmod","chown","close","copyFile","fchmod","fchown","fdatasync","fstat","fsync","ftruncate","futimes","lchmod","lchown","link","lstat","mkdir","mkdtemp","open","opendir","readdir","readFile","readlink","realpath","rename","rm","rmdir","stat","symlink","truncate","unlink","utimes","writeFile"].filter((e=>"function"==typeof n[e]));Object.assign(e,n),r.forEach((r=>{e[r]=t(n[r])})),e.realpath.native=t(n.realpath.native),e.exists=function(e,t){return"function"==typeof t?n.exists(e,t):new Promise((t=>n.exists(e,t)))},e.read=function(e,t,r,u,o,i){return"function"==typeof i?n.read(e,t,r,u,o,i):new Promise(((i,s)=>{n.read(e,t,r,u,o,((e,t,n)=>{if(e)return s(e);i({bytesRead:t,buffer:n})}))}))},e.write=function(e,t,...r){return"function"==typeof r[r.length-1]?n.write(e,t,...r):new Promise(((u,o)=>{n.write(e,t,...r,((e,t,n)=>{if(e)return o(e);u({bytesWritten:t,buffer:n})}))}))},"function"==typeof n.writev&&(e.writev=function(e,t,...r){return"function"==typeof r[r.length-1]?n.writev(e,t,...r):new Promise(((u,o)=>{n.writev(e,t,...r,((e,t,n)=>{if(e)return o(e);u({bytesWritten:t,buffers:n})}))}))})}(ne);var Pe={},ke={};const xe=p.default;ke.checkPath=function(e){if("win32"===process.platform){if(/[<>:"|?*]/.test(e.replace(xe.parse(e).root,""))){const t=new Error(`Path contains invalid characters: ${e}`);throw t.code="EINVAL",t}}};const Ne=ne,{checkPath:Ie}=ke,Te=e=>"number"==typeof e?e:{mode:511,...e}.mode;Pe.makeDir=async(e,t)=>(Ie(e),Ne.mkdir(e,{mode:Te(t),recursive:!0})),Pe.makeDirSync=(e,t)=>(Ie(e),Ne.mkdirSync(e,{mode:Te(t),recursive:!0}));const Re=re.fromPromise,{makeDir:Me,makeDirSync:Le}=Pe,je=Re(Me);var $e={mkdirs:je,mkdirsSync:Le,mkdirp:je,mkdirpSync:Le,ensureDir:je,ensureDirSync:Le};const He=re.fromPromise,Je=ne;var Ge={pathExists:He((function(e){return Je.access(e).then((()=>!0)).catch((()=>!1))})),pathExistsSync:Je.existsSync};const Ve=we;var Ue=function(e,t,n,r){Ve.open(e,"r+",((e,u)=>{if(e)return r(e);Ve.futimes(u,t,n,(e=>{Ve.close(u,(t=>{r&&r(e||t)}))}))}))},We=function(e,t,n){const r=Ve.openSync(e,"r+");return Ve.futimesSync(r,t,n),Ve.closeSync(r)};const ze=ne,Ke=p.default,qe=F.default;function Ye(e,t,n){const r=n.dereference?e=>ze.stat(e,{bigint:!0}):e=>ze.lstat(e,{bigint:!0});return Promise.all([r(e),r(t).catch((e=>{if("ENOENT"===e.code)return null;throw e}))]).then((([e,t])=>({srcStat:e,destStat:t})))}function Xe(e,t){return t.ino&&t.dev&&t.ino===e.ino&&t.dev===e.dev}function Ze(e,t){const n=Ke.resolve(e).split(Ke.sep).filter((e=>e)),r=Ke.resolve(t).split(Ke.sep).filter((e=>e));return n.reduce(((e,t,n)=>e&&r[n]===t),!0)}function Qe(e,t,n){return`Cannot ${n} '${e}' to a subdirectory of itself, '${t}'.`}var et={checkPaths:function(e,t,n,r,u){qe.callbackify(Ye)(e,t,r,((r,o)=>{if(r)return u(r);const{srcStat:i,destStat:s}=o;if(s){if(Xe(i,s)){const r=Ke.basename(e),o=Ke.basename(t);return"move"===n&&r!==o&&r.toLowerCase()===o.toLowerCase()?u(null,{srcStat:i,destStat:s,isChangingCase:!0}):u(new Error("Source and destination must not be the same."))}if(i.isDirectory()&&!s.isDirectory())return u(new Error(`Cannot overwrite non-directory '${t}' with directory '${e}'.`));if(!i.isDirectory()&&s.isDirectory())return u(new Error(`Cannot overwrite directory '${t}' with non-directory '${e}'.`))}return i.isDirectory()&&Ze(e,t)?u(new Error(Qe(e,t,n))):u(null,{srcStat:i,destStat:s})}))},checkPathsSync:function(e,t,n,r){const{srcStat:u,destStat:o}=function(e,t,n){let r;const u=n.dereference?e=>ze.statSync(e,{bigint:!0}):e=>ze.lstatSync(e,{bigint:!0}),o=u(e);try{r=u(t)}catch(e){if("ENOENT"===e.code)return{srcStat:o,destStat:null};throw e}return{srcStat:o,destStat:r}}(e,t,r);if(o){if(Xe(u,o)){const r=Ke.basename(e),i=Ke.basename(t);if("move"===n&&r!==i&&r.toLowerCase()===i.toLowerCase())return{srcStat:u,destStat:o,isChangingCase:!0};throw new Error("Source and destination must not be the same.")}if(u.isDirectory()&&!o.isDirectory())throw new Error(`Cannot overwrite non-directory '${t}' with directory '${e}'.`);if(!u.isDirectory()&&o.isDirectory())throw new Error(`Cannot overwrite directory '${t}' with non-directory '${e}'.`)}if(u.isDirectory()&&Ze(e,t))throw new Error(Qe(e,t,n));return{srcStat:u,destStat:o}},checkParentPaths:function e(t,n,r,u,o){const i=Ke.resolve(Ke.dirname(t)),s=Ke.resolve(Ke.dirname(r));if(s===i||s===Ke.parse(s).root)return o();ze.stat(s,{bigint:!0},((i,c)=>i?"ENOENT"===i.code?o():o(i):Xe(n,c)?o(new Error(Qe(t,r,u))):e(t,n,s,u,o)))},checkParentPathsSync:function e(t,n,r,u){const o=Ke.resolve(Ke.dirname(t)),i=Ke.resolve(Ke.dirname(r));if(i===o||i===Ke.parse(i).root)return;let s;try{s=ze.statSync(i,{bigint:!0})}catch(e){if("ENOENT"===e.code)return;throw e}if(Xe(n,s))throw new Error(Qe(t,r,u));return e(t,n,i,u)},isSrcSubdir:Ze,areIdentical:Xe};const tt=we,nt=p.default,rt=$e.mkdirs,ut=Ge.pathExists,ot=Ue,it=et;function st(e,t,n,r,u){const o=nt.dirname(n);ut(o,((i,s)=>i?u(i):s?at(e,t,n,r,u):void rt(o,(o=>o?u(o):at(e,t,n,r,u)))))}function ct(e,t,n,r,u,o){Promise.resolve(u.filter(n,r)).then((i=>i?e(t,n,r,u,o):o()),(e=>o(e)))}function at(e,t,n,r,u){(r.dereference?tt.stat:tt.lstat)(t,((o,i)=>o?u(o):i.isDirectory()?function(e,t,n,r,u,o){return t?Dt(n,r,u,o):function(e,t,n,r,u){tt.mkdir(n,(o=>{if(o)return u(o);Dt(t,n,r,(t=>t?u(t):dt(n,e,u)))}))}(e.mode,n,r,u,o)}(i,e,t,n,r,u):i.isFile()||i.isCharacterDevice()||i.isBlockDevice()?function(e,t,n,r,u,o){return t?function(e,t,n,r,u){if(!r.overwrite)return r.errorOnExist?u(new Error(`'${n}' already exists`)):u();tt.unlink(n,(o=>o?u(o):lt(e,t,n,r,u)))}(e,n,r,u,o):lt(e,n,r,u,o)}(i,e,t,n,r,u):i.isSymbolicLink()?function(e,t,n,r,u){tt.readlink(t,((t,o)=>t?u(t):(r.dereference&&(o=nt.resolve(process.cwd(),o)),e?void tt.readlink(n,((t,i)=>t?"EINVAL"===t.code||"UNKNOWN"===t.code?tt.symlink(o,n,u):u(t):(r.dereference&&(i=nt.resolve(process.cwd(),i)),it.isSrcSubdir(o,i)?u(new Error(`Cannot copy '${o}' to a subdirectory of itself, '${i}'.`)):e.isDirectory()&&it.isSrcSubdir(i,o)?u(new Error(`Cannot overwrite '${i}' with '${o}'.`)):function(e,t,n){tt.unlink(t,(r=>r?n(r):tt.symlink(e,t,n)))}(o,n,u)))):tt.symlink(o,n,u))))}(e,t,n,r,u):i.isSocket()?u(new Error(`Cannot copy a socket file: ${t}`)):i.isFIFO()?u(new Error(`Cannot copy a FIFO pipe: ${t}`)):u(new Error(`Unknown file: ${t}`))))}function lt(e,t,n,r,u){tt.copyFile(t,n,(o=>o?u(o):r.preserveTimestamps?function(e,t,n,r){if(function(e){return 0==(128&e)}(e))return function(e,t,n){return dt(e,128|t,n)}(n,e,(u=>u?r(u):ft(e,t,n,r)));return ft(e,t,n,r)}(e.mode,t,n,u):dt(n,e.mode,u)))}function ft(e,t,n,r){!function(e,t,n){tt.stat(e,((e,r)=>e?n(e):ot(t,r.atime,r.mtime,n)))}(t,n,(t=>t?r(t):dt(n,e,r)))}function dt(e,t,n){return tt.chmod(e,t,n)}function Dt(e,t,n,r){tt.readdir(e,((u,o)=>u?r(u):pt(o,e,t,n,r)))}function pt(e,t,n,r,u){const o=e.pop();return o?function(e,t,n,r,u,o){const i=nt.join(n,t),s=nt.join(r,t);it.checkPaths(i,s,"copy",u,((t,c)=>{if(t)return o(t);const{destStat:a}=c;!function(e,t,n,r,u){r.filter?ct(at,e,t,n,r,u):at(e,t,n,r,u)}(a,i,s,u,(t=>t?o(t):pt(e,n,r,u,o)))}))}(e,o,t,n,r,u):u()}var Et=function(e,t,n,r){"function"!=typeof n||r?"function"==typeof n&&(n={filter:n}):(r=n,n={}),r=r||function(){},(n=n||{}).clobber=!("clobber"in n)||!!n.clobber,n.overwrite="overwrite"in n?!!n.overwrite:n.clobber,n.preserveTimestamps&&"ia32"===process.arch&&console.warn("fs-extra: Using the preserveTimestamps option in 32-bit node is not recommended;\n\n see https://github.com/jprichardson/node-fs-extra/issues/269"),it.checkPaths(e,t,"copy",n,((u,o)=>{if(u)return r(u);const{srcStat:i,destStat:s}=o;it.checkParentPaths(e,i,t,"copy",(u=>u?r(u):n.filter?ct(st,s,e,t,n,r):st(s,e,t,n,r)))}))};const mt=we,ht=p.default,yt=$e.mkdirsSync,Ct=We,Ft=et;function gt(e,t,n,r){const u=(r.dereference?mt.statSync:mt.lstatSync)(t);if(u.isDirectory())return function(e,t,n,r,u){return t?St(n,r,u):function(e,t,n,r){return mt.mkdirSync(n),St(t,n,r),vt(n,e)}(e.mode,n,r,u)}(u,e,t,n,r);if(u.isFile()||u.isCharacterDevice()||u.isBlockDevice())return function(e,t,n,r,u){return t?function(e,t,n,r){if(r.overwrite)return mt.unlinkSync(n),At(e,t,n,r);if(r.errorOnExist)throw new Error(`'${n}' already exists`)}(e,n,r,u):At(e,n,r,u)}(u,e,t,n,r);if(u.isSymbolicLink())return function(e,t,n,r){let u=mt.readlinkSync(t);r.dereference&&(u=ht.resolve(process.cwd(),u));if(e){let e;try{e=mt.readlinkSync(n)}catch(e){if("EINVAL"===e.code||"UNKNOWN"===e.code)return mt.symlinkSync(u,n);throw e}if(r.dereference&&(e=ht.resolve(process.cwd(),e)),Ft.isSrcSubdir(u,e))throw new Error(`Cannot copy '${u}' to a subdirectory of itself, '${e}'.`);if(mt.statSync(n).isDirectory()&&Ft.isSrcSubdir(e,u))throw new Error(`Cannot overwrite '${e}' with '${u}'.`);return function(e,t){return mt.unlinkSync(t),mt.symlinkSync(e,t)}(u,n)}return mt.symlinkSync(u,n)}(e,t,n,r);if(u.isSocket())throw new Error(`Cannot copy a socket file: ${t}`);if(u.isFIFO())throw new Error(`Cannot copy a FIFO pipe: ${t}`);throw new Error(`Unknown file: ${t}`)}function At(e,t,n,r){return mt.copyFileSync(t,n),r.preserveTimestamps&&function(e,t,n){(function(e){return 0==(128&e)})(e)&&function(e,t){vt(e,128|t)}(n,e);(function(e,t){const n=mt.statSync(e);Ct(t,n.atime,n.mtime)})(t,n)}(e.mode,t,n),vt(n,e.mode)}function vt(e,t){return mt.chmodSync(e,t)}function St(e,t,n){mt.readdirSync(e).forEach((r=>function(e,t,n,r){const u=ht.join(t,e),o=ht.join(n,e),{destStat:i}=Ft.checkPathsSync(u,o,"copy",r);return function(e,t,n,r){if(!r.filter||r.filter(t,n))return gt(e,t,n,r)}(i,u,o,r)}(r,e,t,n)))}var wt=function(e,t,n){"function"==typeof n&&(n={filter:n}),(n=n||{}).clobber=!("clobber"in n)||!!n.clobber,n.overwrite="overwrite"in n?!!n.overwrite:n.clobber,n.preserveTimestamps&&"ia32"===process.arch&&console.warn("fs-extra: Using the preserveTimestamps option in 32-bit node is not recommended;\n\n see https://github.com/jprichardson/node-fs-extra/issues/269");const{srcStat:r,destStat:u}=Ft.checkPathsSync(e,t,"copy",n);return Ft.checkParentPathsSync(e,r,t,"copy"),function(e,t,n,r){if(r.filter&&!r.filter(t,n))return;const u=ht.dirname(n);mt.existsSync(u)||yt(u);return gt(e,t,n,r)}(u,e,t,n)};var Ot={copy:(0,re.fromCallback)(Et),copySync:wt};const bt=we,_t=p.default,Bt=g.default,Pt="win32"===process.platform;function kt(e){["unlink","chmod","stat","lstat","rmdir","readdir"].forEach((t=>{e[t]=e[t]||bt[t],e[t+="Sync"]=e[t]||bt[t]})),e.maxBusyTries=e.maxBusyTries||3}function xt(e,t,n){let r=0;"function"==typeof t&&(n=t,t={}),Bt(e,"rimraf: missing path"),Bt.strictEqual(typeof e,"string","rimraf: path should be a string"),Bt.strictEqual(typeof n,"function","rimraf: callback function required"),Bt(t,"rimraf: invalid options argument provided"),Bt.strictEqual(typeof t,"object","rimraf: options should be object"),kt(t),Nt(e,t,(function u(o){if(o){if(("EBUSY"===o.code||"ENOTEMPTY"===o.code||"EPERM"===o.code)&&rNt(e,t,u)),100*r)}"ENOENT"===o.code&&(o=null)}n(o)}))}function Nt(e,t,n){Bt(e),Bt(t),Bt("function"==typeof n),t.lstat(e,((r,u)=>r&&"ENOENT"===r.code?n(null):r&&"EPERM"===r.code&&Pt?It(e,t,r,n):u&&u.isDirectory()?Rt(e,t,r,n):void t.unlink(e,(r=>{if(r){if("ENOENT"===r.code)return n(null);if("EPERM"===r.code)return Pt?It(e,t,r,n):Rt(e,t,r,n);if("EISDIR"===r.code)return Rt(e,t,r,n)}return n(r)}))))}function It(e,t,n,r){Bt(e),Bt(t),Bt("function"==typeof r),t.chmod(e,438,(u=>{u?r("ENOENT"===u.code?null:n):t.stat(e,((u,o)=>{u?r("ENOENT"===u.code?null:n):o.isDirectory()?Rt(e,t,n,r):t.unlink(e,r)}))}))}function Tt(e,t,n){let r;Bt(e),Bt(t);try{t.chmodSync(e,438)}catch(e){if("ENOENT"===e.code)return;throw n}try{r=t.statSync(e)}catch(e){if("ENOENT"===e.code)return;throw n}r.isDirectory()?Lt(e,t,n):t.unlinkSync(e)}function Rt(e,t,n,r){Bt(e),Bt(t),Bt("function"==typeof r),t.rmdir(e,(u=>{!u||"ENOTEMPTY"!==u.code&&"EEXIST"!==u.code&&"EPERM"!==u.code?u&&"ENOTDIR"===u.code?r(n):r(u):function(e,t,n){Bt(e),Bt(t),Bt("function"==typeof n),t.readdir(e,((r,u)=>{if(r)return n(r);let o,i=u.length;if(0===i)return t.rmdir(e,n);u.forEach((r=>{xt(_t.join(e,r),t,(r=>{if(!o)return r?n(o=r):void(0==--i&&t.rmdir(e,n))}))}))}))}(e,t,r)}))}function Mt(e,t){let n;kt(t=t||{}),Bt(e,"rimraf: missing path"),Bt.strictEqual(typeof e,"string","rimraf: path should be a string"),Bt(t,"rimraf: missing options"),Bt.strictEqual(typeof t,"object","rimraf: options should be object");try{n=t.lstatSync(e)}catch(n){if("ENOENT"===n.code)return;"EPERM"===n.code&&Pt&&Tt(e,t,n)}try{n&&n.isDirectory()?Lt(e,t,null):t.unlinkSync(e)}catch(n){if("ENOENT"===n.code)return;if("EPERM"===n.code)return Pt?Tt(e,t,n):Lt(e,t,n);if("EISDIR"!==n.code)throw n;Lt(e,t,n)}}function Lt(e,t,n){Bt(e),Bt(t);try{t.rmdirSync(e)}catch(r){if("ENOTDIR"===r.code)throw n;if("ENOTEMPTY"===r.code||"EEXIST"===r.code||"EPERM"===r.code)!function(e,t){if(Bt(e),Bt(t),t.readdirSync(e).forEach((n=>Mt(_t.join(e,n),t))),!Pt){return t.rmdirSync(e,t)}{const n=Date.now();do{try{return t.rmdirSync(e,t)}catch{}}while(Date.now()-n<500)}}(e,t);else if("ENOENT"!==r.code)throw r}}var jt=xt;xt.sync=Mt;const $t=we,Ht=re.fromCallback,Jt=jt;var Gt={remove:Ht((function(e,t){if($t.rm)return $t.rm(e,{recursive:!0,force:!0},t);Jt(e,t)})),removeSync:function(e){if($t.rmSync)return $t.rmSync(e,{recursive:!0,force:!0});Jt.sync(e)}};const Vt=re.fromPromise,Ut=ne,Wt=p.default,zt=$e,Kt=Gt,qt=Vt((async function(e){let t;try{t=await Ut.readdir(e)}catch{return zt.mkdirs(e)}return Promise.all(t.map((t=>Kt.remove(Wt.join(e,t)))))}));function Yt(e){let t;try{t=Ut.readdirSync(e)}catch{return zt.mkdirsSync(e)}t.forEach((t=>{t=Wt.join(e,t),Kt.removeSync(t)}))}var Xt={emptyDirSync:Yt,emptydirSync:Yt,emptyDir:qt,emptydir:qt};const Zt=re.fromCallback,Qt=p.default,en=we,tn=$e;var nn={createFile:Zt((function(e,t){function n(){en.writeFile(e,"",(e=>{if(e)return t(e);t()}))}en.stat(e,((r,u)=>{if(!r&&u.isFile())return t();const o=Qt.dirname(e);en.stat(o,((e,r)=>{if(e)return"ENOENT"===e.code?tn.mkdirs(o,(e=>{if(e)return t(e);n()})):t(e);r.isDirectory()?n():en.readdir(o,(e=>{if(e)return t(e)}))}))}))})),createFileSync:function(e){let t;try{t=en.statSync(e)}catch{}if(t&&t.isFile())return;const n=Qt.dirname(e);try{en.statSync(n).isDirectory()||en.readdirSync(n)}catch(e){if(!e||"ENOENT"!==e.code)throw e;tn.mkdirsSync(n)}en.writeFileSync(e,"")}};const rn=re.fromCallback,un=p.default,on=we,sn=$e,cn=Ge.pathExists,{areIdentical:an}=et;var ln={createLink:rn((function(e,t,n){function r(e,t){on.link(e,t,(e=>{if(e)return n(e);n(null)}))}on.lstat(t,((u,o)=>{on.lstat(e,((u,i)=>{if(u)return u.message=u.message.replace("lstat","ensureLink"),n(u);if(o&&an(i,o))return n(null);const s=un.dirname(t);cn(s,((u,o)=>u?n(u):o?r(e,t):void sn.mkdirs(s,(u=>{if(u)return n(u);r(e,t)}))))}))}))})),createLinkSync:function(e,t){let n;try{n=on.lstatSync(t)}catch{}try{const t=on.lstatSync(e);if(n&&an(t,n))return}catch(e){throw e.message=e.message.replace("lstat","ensureLink"),e}const r=un.dirname(t);return on.existsSync(r)||sn.mkdirsSync(r),on.linkSync(e,t)}};const fn=p.default,dn=we,Dn=Ge.pathExists;var pn={symlinkPaths:function(e,t,n){if(fn.isAbsolute(e))return dn.lstat(e,(t=>t?(t.message=t.message.replace("lstat","ensureSymlink"),n(t)):n(null,{toCwd:e,toDst:e})));{const r=fn.dirname(t),u=fn.join(r,e);return Dn(u,((t,o)=>t?n(t):o?n(null,{toCwd:u,toDst:e}):dn.lstat(e,(t=>t?(t.message=t.message.replace("lstat","ensureSymlink"),n(t)):n(null,{toCwd:e,toDst:fn.relative(r,e)})))))}},symlinkPathsSync:function(e,t){let n;if(fn.isAbsolute(e)){if(n=dn.existsSync(e),!n)throw new Error("absolute srcpath does not exist");return{toCwd:e,toDst:e}}{const r=fn.dirname(t),u=fn.join(r,e);if(n=dn.existsSync(u),n)return{toCwd:u,toDst:e};if(n=dn.existsSync(e),!n)throw new Error("relative srcpath does not exist");return{toCwd:e,toDst:fn.relative(r,e)}}}};const En=we;var mn={symlinkType:function(e,t,n){if(n="function"==typeof t?t:n,t="function"!=typeof t&&t)return n(null,t);En.lstat(e,((e,r)=>{if(e)return n(null,"file");t=r&&r.isDirectory()?"dir":"file",n(null,t)}))},symlinkTypeSync:function(e,t){let n;if(t)return t;try{n=En.lstatSync(e)}catch{return"file"}return n&&n.isDirectory()?"dir":"file"}};const hn=re.fromCallback,yn=p.default,Cn=ne,Fn=$e.mkdirs,gn=$e.mkdirsSync,An=pn.symlinkPaths,vn=pn.symlinkPathsSync,Sn=mn.symlinkType,wn=mn.symlinkTypeSync,On=Ge.pathExists,{areIdentical:bn}=et;function _n(e,t,n,r){An(e,t,((u,o)=>{if(u)return r(u);e=o.toDst,Sn(o.toCwd,n,((n,u)=>{if(n)return r(n);const o=yn.dirname(t);On(o,((n,i)=>n?r(n):i?Cn.symlink(e,t,u,r):void Fn(o,(n=>{if(n)return r(n);Cn.symlink(e,t,u,r)}))))}))}))}var Bn={createSymlink:hn((function(e,t,n,r){r="function"==typeof n?n:r,n="function"!=typeof n&&n,Cn.lstat(t,((u,o)=>{!u&&o.isSymbolicLink()?Promise.all([Cn.stat(e),Cn.stat(t)]).then((([u,o])=>{if(bn(u,o))return r(null);_n(e,t,n,r)})):_n(e,t,n,r)}))})),createSymlinkSync:function(e,t,n){let r;try{r=Cn.lstatSync(t)}catch{}if(r&&r.isSymbolicLink()){const n=Cn.statSync(e),r=Cn.statSync(t);if(bn(n,r))return}const u=vn(e,t);e=u.toDst,n=wn(u.toCwd,n);const o=yn.dirname(t);return Cn.existsSync(o)||gn(o),Cn.symlinkSync(e,t,n)}};const{createFile:Pn,createFileSync:kn}=nn,{createLink:xn,createLinkSync:Nn}=ln,{createSymlink:In,createSymlinkSync:Tn}=Bn;var Rn={createFile:Pn,createFileSync:kn,ensureFile:Pn,ensureFileSync:kn,createLink:xn,createLinkSync:Nn,ensureLink:xn,ensureLinkSync:Nn,createSymlink:In,createSymlinkSync:Tn,ensureSymlink:In,ensureSymlinkSync:Tn};var Mn={stringify:function(e,{EOL:t="\n",finalEOL:n=!0,replacer:r=null,spaces:u}={}){const o=n?t:"";return JSON.stringify(e,r,u).replace(/\n/g,t)+o},stripBom:function(e){return Buffer.isBuffer(e)&&(e=e.toString("utf8")),e.replace(/^\uFEFF/,"")}};let Ln;try{Ln=we}catch(e){Ln=D.default}const jn=re,{stringify:$n,stripBom:Hn}=Mn;const Jn=jn.fromPromise((async function(e,t={}){"string"==typeof t&&(t={encoding:t});const n=t.fs||Ln,r=!("throws"in t)||t.throws;let u,o=await jn.fromCallback(n.readFile)(e,t);o=Hn(o);try{u=JSON.parse(o,t?t.reviver:null)}catch(t){if(r)throw t.message=`${e}: ${t.message}`,t;return null}return u}));const Gn=jn.fromPromise((async function(e,t,n={}){const r=n.fs||Ln,u=$n(t,n);await jn.fromCallback(r.writeFile)(e,u,n)}));const Vn={readFile:Jn,readFileSync:function(e,t={}){"string"==typeof t&&(t={encoding:t});const n=t.fs||Ln,r=!("throws"in t)||t.throws;try{let r=n.readFileSync(e,t);return r=Hn(r),JSON.parse(r,t.reviver)}catch(t){if(r)throw t.message=`${e}: ${t.message}`,t;return null}},writeFile:Gn,writeFileSync:function(e,t,n={}){const r=n.fs||Ln,u=$n(t,n);return r.writeFileSync(e,u,n)}};var Un={readJson:Vn.readFile,readJsonSync:Vn.readFileSync,writeJson:Vn.writeFile,writeJsonSync:Vn.writeFileSync};const Wn=re.fromCallback,zn=we,Kn=p.default,qn=$e,Yn=Ge.pathExists;var Xn={outputFile:Wn((function(e,t,n,r){"function"==typeof n&&(r=n,n="utf8");const u=Kn.dirname(e);Yn(u,((o,i)=>o?r(o):i?zn.writeFile(e,t,n,r):void qn.mkdirs(u,(u=>{if(u)return r(u);zn.writeFile(e,t,n,r)}))))})),outputFileSync:function(e,...t){const n=Kn.dirname(e);if(zn.existsSync(n))return zn.writeFileSync(e,...t);qn.mkdirsSync(n),zn.writeFileSync(e,...t)}};const{stringify:Zn}=Mn,{outputFile:Qn}=Xn;var er=async function(e,t,n={}){const r=Zn(t,n);await Qn(e,r,n)};const{stringify:tr}=Mn,{outputFileSync:nr}=Xn;var rr=function(e,t,n){const r=tr(t,n);nr(e,r,n)};const ur=re.fromPromise,or=Un;or.outputJson=ur(er),or.outputJsonSync=rr,or.outputJSON=or.outputJson,or.outputJSONSync=or.outputJsonSync,or.writeJSON=or.writeJson,or.writeJSONSync=or.writeJsonSync,or.readJSON=or.readJson,or.readJSONSync=or.readJsonSync;var ir=or;const sr=we,cr=p.default,ar=Ot.copy,lr=Gt.remove,fr=$e.mkdirp,dr=Ge.pathExists,Dr=et;function pr(e,t,n,r,u){return r?Er(e,t,n,u):n?lr(t,(r=>r?u(r):Er(e,t,n,u))):void dr(t,((r,o)=>r?u(r):o?u(new Error("dest already exists.")):Er(e,t,n,u)))}function Er(e,t,n,r){sr.rename(e,t,(u=>u?"EXDEV"!==u.code?r(u):function(e,t,n,r){const u={overwrite:n,errorOnExist:!0};ar(e,t,u,(t=>t?r(t):lr(e,r)))}(e,t,n,r):r()))}var mr=function(e,t,n,r){"function"==typeof n&&(r=n,n={});const u=n.overwrite||n.clobber||!1;Dr.checkPaths(e,t,"move",n,((n,o)=>{if(n)return r(n);const{srcStat:i,isChangingCase:s=!1}=o;Dr.checkParentPaths(e,i,t,"move",(n=>n?r(n):function(e){const t=cr.dirname(e);return cr.parse(t).root===t}(t)?pr(e,t,u,s,r):void fr(cr.dirname(t),(n=>n?r(n):pr(e,t,u,s,r)))))}))};const hr=we,yr=p.default,Cr=Ot.copySync,Fr=Gt.removeSync,gr=$e.mkdirpSync,Ar=et;function vr(e,t,n){try{hr.renameSync(e,t)}catch(r){if("EXDEV"!==r.code)throw r;return function(e,t,n){const r={overwrite:n,errorOnExist:!0};return Cr(e,t,r),Fr(e)}(e,t,n)}}var Sr=function(e,t,n){const r=(n=n||{}).overwrite||n.clobber||!1,{srcStat:u,isChangingCase:o=!1}=Ar.checkPathsSync(e,t,"move",n);return Ar.checkParentPathsSync(e,u,t,"move"),function(e){const t=yr.dirname(e);return yr.parse(t).root===t}(t)||gr(yr.dirname(t)),function(e,t,n,r){if(r)return vr(e,t,n);if(n)return Fr(t),vr(e,t,n);if(hr.existsSync(t))throw new Error("dest already exists.");return vr(e,t,n)}(e,t,r,o)};var wr,Or,br,_r,Br,Pr={move:(0,re.fromCallback)(mr),moveSync:Sr},kr={...ne,...Ot,...Xt,...Rn,...ir,...$e,...Pr,...Xn,...Ge,...Gt},xr={},Nr={exports:{}},Ir={exports:{}};function Tr(){if(Or)return wr;Or=1;var e=1e3,t=60*e,n=60*t,r=24*n,u=7*r,o=365.25*r;function i(e,t,n,r){var u=t>=1.5*n;return Math.round(e/n)+" "+r+(u?"s":"")}return wr=function(s,c){c=c||{};var a=typeof s;if("string"===a&&s.length>0)return function(i){if((i=String(i)).length>100)return;var s=/^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(i);if(!s)return;var c=parseFloat(s[1]);switch((s[2]||"ms").toLowerCase()){case"years":case"year":case"yrs":case"yr":case"y":return c*o;case"weeks":case"week":case"w":return c*u;case"days":case"day":case"d":return c*r;case"hours":case"hour":case"hrs":case"hr":case"h":return c*n;case"minutes":case"minute":case"mins":case"min":case"m":return c*t;case"seconds":case"second":case"secs":case"sec":case"s":return c*e;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return c;default:return}}(s);if("number"===a&&isFinite(s))return c.long?function(u){var o=Math.abs(u);if(o>=r)return i(u,o,r,"day");if(o>=n)return i(u,o,n,"hour");if(o>=t)return i(u,o,t,"minute");if(o>=e)return i(u,o,e,"second");return u+" ms"}(s):function(u){var o=Math.abs(u);if(o>=r)return Math.round(u/r)+"d";if(o>=n)return Math.round(u/n)+"h";if(o>=t)return Math.round(u/t)+"m";if(o>=e)return Math.round(u/e)+"s";return u+"ms"}(s);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(s))}}function Rr(){if(_r)return br;return _r=1,br=function(e){function t(e){let r,u,o,i=null;function s(...e){if(!s.enabled)return;const n=s,u=Number(new Date),o=u-(r||u);n.diff=o,n.prev=r,n.curr=u,r=u,e[0]=t.coerce(e[0]),"string"!=typeof e[0]&&e.unshift("%O");let i=0;e[0]=e[0].replace(/%([a-zA-Z%])/g,((r,u)=>{if("%%"===r)return"%";i++;const o=t.formatters[u];if("function"==typeof o){const t=e[i];r=o.call(n,t),e.splice(i,1),i--}return r})),t.formatArgs.call(n,e);(n.log||t.log).apply(n,e)}return s.namespace=e,s.useColors=t.useColors(),s.color=t.selectColor(e),s.extend=n,s.destroy=t.destroy,Object.defineProperty(s,"enabled",{enumerable:!0,configurable:!1,get:()=>null!==i?i:(u!==t.namespaces&&(u=t.namespaces,o=t.enabled(e)),o),set:e=>{i=e}}),"function"==typeof t.init&&t.init(s),s}function n(e,n){const r=t(this.namespace+(void 0===n?":":n)+e);return r.log=this.log,r}function r(e){return e.toString().substring(2,e.toString().length-2).replace(/\.\*\?$/,"*")}return t.debug=t,t.default=t,t.coerce=function(e){if(e instanceof Error)return e.stack||e.message;return e},t.disable=function(){const e=[...t.names.map(r),...t.skips.map(r).map((e=>"-"+e))].join(",");return t.enable(""),e},t.enable=function(e){let n;t.save(e),t.namespaces=e,t.names=[],t.skips=[];const r=("string"==typeof e?e:"").split(/[\s,]+/),u=r.length;for(n=0;n{t[n]=e[n]})),t.names=[],t.skips=[],t.formatters={},t.selectColor=function(e){let n=0;for(let t=0;t{const n=e.startsWith("-")?"":1===e.length?"-":"--",r=t.indexOf(n+e),u=t.indexOf("--");return-1!==r&&(-1===u||r{}),"Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."),t.colors=[6,2,3,4,5,1];try{const e=function(){if($r)return jr;$r=1;const e=E.default,t=A.default,n=Vr(),{env:r}=process;let u;function o(e){return 0!==e&&{level:e,hasBasic:!0,has256:e>=2,has16m:e>=3}}function i(t,o){if(0===u)return 0;if(n("color=16m")||n("color=full")||n("color=truecolor"))return 3;if(n("color=256"))return 2;if(t&&!o&&void 0===u)return 0;const i=u||0;if("dumb"===r.TERM)return i;if("win32"===process.platform){const t=e.release().split(".");return Number(t[0])>=10&&Number(t[2])>=10586?Number(t[2])>=14931?3:2:1}if("CI"in r)return["TRAVIS","CIRCLECI","APPVEYOR","GITLAB_CI","GITHUB_ACTIONS","BUILDKITE"].some((e=>e in r))||"codeship"===r.CI_NAME?1:i;if("TEAMCITY_VERSION"in r)return/^(9\.(0*[1-9]\d*)\.|\d{2,}\.)/.test(r.TEAMCITY_VERSION)?1:0;if("truecolor"===r.COLORTERM)return 3;if("TERM_PROGRAM"in r){const e=parseInt((r.TERM_PROGRAM_VERSION||"").split(".")[0],10);switch(r.TERM_PROGRAM){case"iTerm.app":return e>=3?3:2;case"Apple_Terminal":return 2}}return/-256(color)?$/i.test(r.TERM)?2:/^screen|^xterm|^vt100|^vt220|^rxvt|color|ansi|cygwin|linux/i.test(r.TERM)||"COLORTERM"in r?1:i}return n("no-color")||n("no-colors")||n("color=false")||n("color=never")?u=0:(n("color")||n("colors")||n("color=true")||n("color=always"))&&(u=1),"FORCE_COLOR"in r&&(u="true"===r.FORCE_COLOR?1:"false"===r.FORCE_COLOR?0:0===r.FORCE_COLOR.length?1:Math.min(parseInt(r.FORCE_COLOR,10),3)),jr={supportsColor:function(e){return o(i(e,e&&e.isTTY))},stdout:o(i(!0,t.isatty(1))),stderr:o(i(!0,t.isatty(2)))}}();e&&(e.stderr||e).level>=2&&(t.colors=[20,21,26,27,32,33,38,39,40,41,42,43,44,45,56,57,62,63,68,69,74,75,76,77,78,79,80,81,92,93,98,99,112,113,128,129,134,135,148,149,160,161,162,163,164,165,166,167,168,169,170,171,172,173,178,179,184,185,196,197,198,199,200,201,202,203,204,205,206,207,208,209,214,215,220,221])}catch(e){}t.inspectOpts=Object.keys(process.env).filter((e=>/^debug_/i.test(e))).reduce(((e,t)=>{const n=t.substring(6).toLowerCase().replace(/_([a-z])/g,((e,t)=>t.toUpperCase()));let r=process.env[t];return r=!!/^(yes|on|true|enabled)$/i.test(r)||!/^(no|off|false|disabled)$/i.test(r)&&("null"===r?null:Number(r)),e[n]=r,e}),{}),e.exports=Rr()(t);const{formatters:u}=e.exports;u.o=function(e){return this.inspectOpts.colors=this.useColors,r.inspect(e,this.inspectOpts).split("\n").map((e=>e.trim())).join(" ")},u.O=function(e){return this.inspectOpts.colors=this.useColors,r.inspect(e,this.inspectOpts)}}(Gr,Gr.exports)),Gr.exports}Jr=Nr,"undefined"==typeof process||"renderer"===process.type||!0===process.browser||process.__nwjs?Jr.exports=(Br||(Br=1,function(e,t){t.formatArgs=function(t){if(t[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+t[0]+(this.useColors?"%c ":" ")+"+"+e.exports.humanize(this.diff),!this.useColors)return;const n="color: "+this.color;t.splice(1,0,n,"color: inherit");let r=0,u=0;t[0].replace(/%[a-zA-Z%]/g,(e=>{"%%"!==e&&(r++,"%c"===e&&(u=r))})),t.splice(u,0,n)},t.save=function(e){try{e?t.storage.setItem("debug",e):t.storage.removeItem("debug")}catch(e){}},t.load=function(){let e;try{e=t.storage.getItem("debug")}catch(e){}return!e&&"undefined"!=typeof process&&"env"in process&&(e=process.env.DEBUG),e},t.useColors=function(){return!("undefined"==typeof window||!window.process||"renderer"!==window.process.type&&!window.process.__nwjs)||("undefined"==typeof navigator||!navigator.userAgent||!navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/))&&("undefined"!=typeof document&&document.documentElement&&document.documentElement.style&&document.documentElement.style.WebkitAppearance||"undefined"!=typeof window&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||"undefined"!=typeof navigator&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/)&&parseInt(RegExp.$1,10)>=31||"undefined"!=typeof navigator&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/))},t.storage=function(){try{return localStorage}catch(e){}}(),t.destroy=(()=>{let e=!1;return()=>{e||(e=!0,console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."))}})(),t.colors=["#0000CC","#0000FF","#0033CC","#0033FF","#0066CC","#0066FF","#0099CC","#0099FF","#00CC00","#00CC33","#00CC66","#00CC99","#00CCCC","#00CCFF","#3300CC","#3300FF","#3333CC","#3333FF","#3366CC","#3366FF","#3399CC","#3399FF","#33CC00","#33CC33","#33CC66","#33CC99","#33CCCC","#33CCFF","#6600CC","#6600FF","#6633CC","#6633FF","#66CC00","#66CC33","#9900CC","#9900FF","#9933CC","#9933FF","#99CC00","#99CC33","#CC0000","#CC0033","#CC0066","#CC0099","#CC00CC","#CC00FF","#CC3300","#CC3333","#CC3366","#CC3399","#CC33CC","#CC33FF","#CC6600","#CC6633","#CC9900","#CC9933","#CCCC00","#CCCC33","#FF0000","#FF0033","#FF0066","#FF0099","#FF00CC","#FF00FF","#FF3300","#FF3333","#FF3366","#FF3399","#FF33CC","#FF33FF","#FF6600","#FF6633","#FF9900","#FF9933","#FFCC00","#FFCC33"],t.log=console.debug||console.log||(()=>{}),e.exports=Rr()(t);const{formatters:n}=e.exports;n.j=function(e){try{return JSON.stringify(e)}catch(e){return"[UnexpectedJSONParseError]: "+e.message}}}(Ir,Ir.exports)),Ir.exports):Jr.exports=Ur();var Wr=function(e){return(e=e||{}).circles?function(e){var t=[],n=[];return e.proto?function e(u){if("object"!=typeof u||null===u)return u;if(u instanceof Date)return new Date(u);if(Array.isArray(u))return r(u,e);if(u instanceof Map)return new Map(r(Array.from(u),e));if(u instanceof Set)return new Set(r(Array.from(u),e));var o={};for(var i in t.push(u),n.push(o),u){var s=u[i];if("object"!=typeof s||null===s)o[i]=s;else if(s instanceof Date)o[i]=new Date(s);else if(s instanceof Map)o[i]=new Map(r(Array.from(s),e));else if(s instanceof Set)o[i]=new Set(r(Array.from(s),e));else if(ArrayBuffer.isView(s))o[i]=zr(s);else{var c=t.indexOf(s);o[i]=-1!==c?n[c]:e(s)}}return t.pop(),n.pop(),o}:function e(u){if("object"!=typeof u||null===u)return u;if(u instanceof Date)return new Date(u);if(Array.isArray(u))return r(u,e);if(u instanceof Map)return new Map(r(Array.from(u),e));if(u instanceof Set)return new Set(r(Array.from(u),e));var o={};for(var i in t.push(u),n.push(o),u)if(!1!==Object.hasOwnProperty.call(u,i)){var s=u[i];if("object"!=typeof s||null===s)o[i]=s;else if(s instanceof Date)o[i]=new Date(s);else if(s instanceof Map)o[i]=new Map(r(Array.from(s),e));else if(s instanceof Set)o[i]=new Set(r(Array.from(s),e));else if(ArrayBuffer.isView(s))o[i]=zr(s);else{var c=t.indexOf(s);o[i]=-1!==c?n[c]:e(s)}}return t.pop(),n.pop(),o};function r(e,r){for(var u=Object.keys(e),o=new Array(u.length),i=0;i!e,Qr=e=>e&&"object"==typeof e&&!Array.isArray(e),eu=(e,t,n)=>{(Array.isArray(t)?t:[t]).forEach((t=>{if(t)throw new Error(`Problem with log4js configuration: (${Kr.inspect(e,{depth:5})}) - ${n}`)}))};var tu={configure:e=>{qr("New configuration to be validated: ",e),eu(e,Zr(Qr(e)),"must be an object."),qr(`Calling pre-processing listeners (${Yr.length})`),Yr.forEach((t=>t(e))),qr("Configuration pre-processing finished."),qr(`Calling configuration listeners (${Xr.length})`),Xr.forEach((t=>t(e))),qr("Configuration finished.")},addListener:e=>{Xr.push(e),qr(`Added listener, now ${Xr.length} listeners`)},addPreProcessingListener:e=>{Yr.push(e),qr(`Added pre-processing listener, now ${Yr.length} listeners`)},throwExceptionIf:eu,anObject:Qr,anInteger:e=>e&&"number"==typeof e&&Number.isInteger(e),validIdentifier:e=>/^[A-Za-z][A-Za-z0-9_]*$/g.test(e),not:Zr},nu={exports:{}};!function(e){function t(e,t){for(var n=e.toString();n.length-1?s:c,l=n(u.getHours()),f=n(u.getMinutes()),d=n(u.getSeconds()),D=t(u.getMilliseconds(),3),p=function(e){var t=Math.abs(e),n=String(Math.floor(t/60)),r=String(t%60);return n=("0"+n).slice(-2),r=("0"+r).slice(-2),0===e?"Z":(e<0?"+":"-")+n+":"+r}(u.getTimezoneOffset());return r.replace(/dd/g,o).replace(/MM/g,i).replace(/y{1,4}/g,a).replace(/hh/g,l).replace(/mm/g,f).replace(/ss/g,d).replace(/SSS/g,D).replace(/O/g,p)}function u(e,t,n,r){e["set"+(r?"":"UTC")+t](n)}e.exports=r,e.exports.asString=r,e.exports.parse=function(t,n,r){if(!t)throw new Error("pattern must be supplied");return function(t,n,r){var o=t.indexOf("O")<0,i=!1,s=[{pattern:/y{1,4}/,regexp:"\\d{1,4}",fn:function(e,t){u(e,"FullYear",t,o)}},{pattern:/MM/,regexp:"\\d{1,2}",fn:function(e,t){u(e,"Month",t-1,o),e.getMonth()!==t-1&&(i=!0)}},{pattern:/dd/,regexp:"\\d{1,2}",fn:function(e,t){i&&u(e,"Month",e.getMonth()-1,o),u(e,"Date",t,o)}},{pattern:/hh/,regexp:"\\d{1,2}",fn:function(e,t){u(e,"Hours",t,o)}},{pattern:/mm/,regexp:"\\d\\d",fn:function(e,t){u(e,"Minutes",t,o)}},{pattern:/ss/,regexp:"\\d\\d",fn:function(e,t){u(e,"Seconds",t,o)}},{pattern:/SSS/,regexp:"\\d\\d\\d",fn:function(e,t){u(e,"Milliseconds",t,o)}},{pattern:/O/,regexp:"[+-]\\d{1,2}:?\\d{2}?|Z",fn:function(e,t){t="Z"===t?0:t.replace(":","");var n=Math.abs(t),r=(t>0?-1:1)*(n%100+60*Math.floor(n/100));e.setUTCMinutes(e.getUTCMinutes()+r)}}],c=s.reduce((function(e,t){return t.pattern.test(e.regexp)?(t.index=e.regexp.match(t.pattern).index,e.regexp=e.regexp.replace(t.pattern,"("+t.regexp+")")):t.index=-1,e}),{regexp:t,index:[]}),a=s.filter((function(e){return e.index>-1}));a.sort((function(e,t){return e.index-t.index}));var l=new RegExp(c.regexp).exec(n);if(l){var f=r||e.exports.now();return a.forEach((function(e,t){e.fn(f,l[t+1])})),f}throw new Error("String '"+n+"' could not be parsed as '"+t+"'")}(t,n,r)},e.exports.now=function(){return new Date},e.exports.ISO8601_FORMAT="yyyy-MM-ddThh:mm:ss.SSS",e.exports.ISO8601_WITH_TZ_OFFSET_FORMAT="yyyy-MM-ddThh:mm:ss.SSSO",e.exports.DATETIME_FORMAT="dd MM yyyy hh:mm:ss.SSS",e.exports.ABSOLUTETIME_FORMAT="hh:mm:ss.SSS"}(nu);const ru=nu.exports,uu=E.default,ou=F.default,iu=p.default,su={bold:[1,22],italic:[3,23],underline:[4,24],inverse:[7,27],white:[37,39],grey:[90,39],black:[90,39],blue:[34,39],cyan:[36,39],green:[32,39],magenta:[35,39],red:[91,39],yellow:[33,39]};function cu(e){return e?`[${su[e][0]}m`:""}function au(e){return e?`[${su[e][1]}m`:""}function lu(e,t){return n=ou.format("[%s] [%s] %s - ",ru.asString(e.startTime),e.level.toString(),e.categoryName),cu(r=t)+n+au(r);var n,r}function fu(e){return lu(e)+ou.format(...e.data)}function du(e){return lu(e,e.level.colour)+ou.format(...e.data)}function Du(e){return ou.format(...e.data)}function pu(e){return e.data[0]}function Eu(e,t){const n=/%(-?[0-9]+)?(\.?-?[0-9]+)?([[\]cdhmnprzxXyflos%])(\{([^}]+)\})?|([^%]+)/;function r(e){return e&&e.pid?e.pid.toString():process.pid.toString()}e=e||"%r %p %c - %m%n";const u={c:function(e,t){let n=e.categoryName;if(t){const e=parseInt(t,10),r=n.split(".");ee&&(n=r.slice(-e).join(iu.sep))}return n},l:function(e){return e.lineNumber?`${e.lineNumber}`:""},o:function(e){return e.columnNumber?`${e.columnNumber}`:""},s:function(e){return e.callStack||""}};function o(e,t,n){return u[e](t,n)}function i(e,t,n){let r=e;return r=function(e,t){let n;return e?(n=parseInt(e.substr(1),10),n>0?t.slice(0,n):t.slice(n)):t}(t,r),r=function(e,t){let n;if(e)if("-"===e.charAt(0))for(n=parseInt(e.substr(1),10);t.lengthDu,basic:()=>fu,colored:()=>du,coloured:()=>du,pattern:e=>Eu(e&&e.pattern,e&&e.tokens),dummy:()=>pu};var hu={basicLayout:fu,messagePassThroughLayout:Du,patternLayout:Eu,colouredLayout:du,coloredLayout:du,dummyLayout:pu,addLayout(e,t){mu[e]=t},layout:(e,t)=>mu[e]&&mu[e](t)};const yu=tu,Cu=["white","grey","black","blue","cyan","green","magenta","red","yellow"];class Fu{constructor(e,t,n){this.level=e,this.levelStr=t,this.colour=n}toString(){return this.levelStr}static getLevel(e,t){return e?e instanceof Fu?e:(e instanceof Object&&e.levelStr&&(e=e.levelStr),Fu[e.toString().toUpperCase()]||t):t}static addLevels(e){if(e){Object.keys(e).forEach((t=>{const n=t.toUpperCase();Fu[n]=new Fu(e[t].value,n,e[t].colour);const r=Fu.levels.findIndex((e=>e.levelStr===n));r>-1?Fu.levels[r]=Fu[n]:Fu.levels.push(Fu[n])})),Fu.levels.sort(((e,t)=>e.level-t.level))}}isLessThanOrEqualTo(e){return"string"==typeof e&&(e=Fu.getLevel(e)),this.level<=e.level}isGreaterThanOrEqualTo(e){return"string"==typeof e&&(e=Fu.getLevel(e)),this.level>=e.level}isEqualTo(e){return"string"==typeof e&&(e=Fu.getLevel(e)),this.level===e.level}}Fu.levels=[],Fu.addLevels({ALL:{value:Number.MIN_VALUE,colour:"grey"},TRACE:{value:5e3,colour:"blue"},DEBUG:{value:1e4,colour:"cyan"},INFO:{value:2e4,colour:"green"},WARN:{value:3e4,colour:"yellow"},ERROR:{value:4e4,colour:"red"},FATAL:{value:5e4,colour:"magenta"},MARK:{value:9007199254740992,colour:"grey"},OFF:{value:Number.MAX_VALUE,colour:"grey"}}),yu.addListener((e=>{const t=e.levels;if(t){yu.throwExceptionIf(e,yu.not(yu.anObject(t)),"levels must be an object");Object.keys(t).forEach((n=>{yu.throwExceptionIf(e,yu.not(yu.validIdentifier(n)),`level name "${n}" is not a valid identifier (must start with a letter, only contain A-Z,a-z,0-9,_)`),yu.throwExceptionIf(e,yu.not(yu.anObject(t[n])),`level "${n}" must be an object`),yu.throwExceptionIf(e,yu.not(t[n].value),`level "${n}" must have a 'value' property`),yu.throwExceptionIf(e,yu.not(yu.anInteger(t[n].value)),`level "${n}".value must have an integer value`),yu.throwExceptionIf(e,yu.not(t[n].colour),`level "${n}" must have a 'colour' property`),yu.throwExceptionIf(e,yu.not(Cu.indexOf(t[n].colour)>-1),`level "${n}".colour must be one of ${Cu.join(", ")}`)}))}})),yu.addListener((e=>{Fu.addLevels(e.levels)}));var gu=Fu,Au={exports:{}},vu={};/*! (c) 2020 Andrea Giammarchi */
-const{parse:Su,stringify:wu}=JSON,{keys:Ou}=Object,bu=String,_u="string",Bu={},Pu="object",ku=(e,t)=>t,xu=e=>e instanceof bu?bu(e):e,Nu=(e,t)=>typeof t===_u?new bu(t):t,Iu=(e,t,n,r)=>{const u=[];for(let o=Ou(n),{length:i}=o,s=0;s{const r=bu(t.push(n)-1);return e.set(n,r),r},Ru=(e,t)=>{const n=Su(e,Nu).map(xu),r=n[0],u=t||ku,o=typeof r===Pu&&r?Iu(n,new Set,r,u):r;return u.call({"":o},"",o)};vu.parse=Ru;const Mu=(e,t,n)=>{const r=t&&typeof t===Pu?(e,n)=>""===e||-1Su(Mu(e));vu.fromJSON=e=>Ru(wu(e));const Lu=vu,ju=gu;class $u{constructor(e,t,n,r,u){this.startTime=new Date,this.categoryName=e,this.data=n,this.level=t,this.context=Object.assign({},r),this.pid=process.pid,u&&(this.functionName=u.functionName,this.fileName=u.fileName,this.lineNumber=u.lineNumber,this.columnNumber=u.columnNumber,this.callStack=u.callStack)}serialise(){const e=this.data.map((e=>(e&&e.message&&e.stack&&(e=Object.assign({message:e.message,stack:e.stack},e)),e)));return this.data=e,Lu.stringify(this)}static deserialise(e){let t;try{const n=Lu.parse(e);n.data=n.data.map((e=>{if(e&&e.message&&e.stack){const t=new Error(e);Object.keys(e).forEach((n=>{t[n]=e[n]})),e=t}return e})),t=new $u(n.categoryName,ju.getLevel(n.level.levelStr),n.data,n.context),t.startTime=new Date(n.startTime),t.pid=n.pid,t.cluster=n.cluster}catch(n){t=new $u("log4js",ju.ERROR,["Unable to parse log:",e,"because: ",n])}return t}}var Hu=$u;const Ju=Nr.exports("log4js:clustering"),Gu=Hu,Vu=tu;let Uu=!1,Wu=null;try{Wu=require("cluster")}catch(e){Ju("cluster module not present"),Uu=!0}const zu=[];let Ku=!1,qu="NODE_APP_INSTANCE";const Yu=()=>Ku&&"0"===process.env[qu],Xu=()=>Uu||Wu.isMaster||Yu(),Zu=e=>{zu.forEach((t=>t(e)))},Qu=(e,t)=>{if(Ju("cluster message received from worker ",e,": ",t),e.topic&&e.data&&(t=e,e=void 0),t&&t.topic&&"log4js:message"===t.topic){Ju("received message: ",t.data);const e=Gu.deserialise(t.data);Zu(e)}};Uu||Vu.addListener((e=>{zu.length=0,({pm2:Ku,disableClustering:Uu,pm2InstanceVar:qu="NODE_APP_INSTANCE"}=e),Ju(`clustering disabled ? ${Uu}`),Ju(`cluster.isMaster ? ${Wu&&Wu.isMaster}`),Ju(`pm2 enabled ? ${Ku}`),Ju(`pm2InstanceVar = ${qu}`),Ju(`process.env[${qu}] = ${process.env[qu]}`),Ku&&process.removeListener("message",Qu),Wu&&Wu.removeListener&&Wu.removeListener("message",Qu),Uu||e.disableClustering?Ju("Not listening for cluster messages, because clustering disabled."):Yu()?(Ju("listening for PM2 broadcast messages"),process.on("message",Qu)):Wu.isMaster?(Ju("listening for cluster messages"),Wu.on("message",Qu)):Ju("not listening for messages, because we are not a master process")}));var eo={onlyOnMaster:(e,t)=>Xu()?e():t,isMaster:Xu,send:e=>{Xu()?Zu(e):(Ku||(e.cluster={workerId:Wu.worker.id,worker:process.pid}),process.send({topic:"log4js:message",data:e.serialise()}))},onMessage:e=>{zu.push(e)}},to={};function no(e){if("number"==typeof e&&Number.isInteger(e))return e;const t={K:1024,M:1048576,G:1073741824},n=Object.keys(t),r=e.substr(e.length-1).toLocaleUpperCase(),u=e.substring(0,e.length-1).trim();if(n.indexOf(r)<0||!Number.isInteger(Number(u)))throw Error(`maxLogSize: "${e}" is invalid`);return u*t[r]}function ro(e){return function(e,t){const n=Object.assign({},t);return Object.keys(e).forEach((r=>{n[r]&&(n[r]=e[r](t[r]))})),n}({maxLogSize:no},e)}const uo={file:ro,fileSync:ro};to.modifyConfig=e=>uo[e.type]?uo[e.type](e):e;var oo={};const io=console.log.bind(console);oo.configure=function(e,t){let n=t.colouredLayout;return e.layout&&(n=t.layout(e.layout.type,e.layout)),function(e,t){return n=>{io(e(n,t))}}(n,e.timezoneOffset)};var so={};so.configure=function(e,t){let n=t.colouredLayout;return e.layout&&(n=t.layout(e.layout.type,e.layout)),function(e,t){return n=>{process.stdout.write(`${e(n,t)}\n`)}}(n,e.timezoneOffset)};var co={};co.configure=function(e,t){let n=t.colouredLayout;return e.layout&&(n=t.layout(e.layout.type,e.layout)),function(e,t){return n=>{process.stderr.write(`${e(n,t)}\n`)}}(n,e.timezoneOffset)};var ao={};ao.configure=function(e,t,n,r){const u=n(e.appender);return function(e,t,n,r){const u=r.getLevel(e),o=r.getLevel(t,r.FATAL);return e=>{const t=e.level;t.isGreaterThanOrEqualTo(u)&&t.isLessThanOrEqualTo(o)&&n(e)}}(e.level,e.maxLevel,u,r)};var lo={};const fo=Nr.exports("log4js:categoryFilter");lo.configure=function(e,t,n){const r=n(e.appender);return function(e,t){return"string"==typeof e&&(e=[e]),n=>{fo(`Checking ${n.categoryName} against ${e}`),-1===e.indexOf(n.categoryName)&&(fo("Not excluded, sending to appender"),t(n))}}(e.exclude,r)};var Do={};const po=Nr.exports("log4js:noLogFilter");Do.configure=function(e,t,n){const r=n(e.appender);return function(e,t){return n=>{po(`Checking data: ${n.data} against filters: ${e}`),"string"==typeof e&&(e=[e]),e=e.filter((e=>null!=e&&""!==e));const r=new RegExp(e.join("|"),"i");(0===e.length||n.data.findIndex((e=>r.test(e)))<0)&&(po("Not excluded, sending to appender"),t(n))}}(e.exclude,r)};var Eo={},mo={exports:{}},ho={},yo={fromCallback:function(e){return Object.defineProperty((function(){if("function"!=typeof arguments[arguments.length-1])return new Promise(((t,n)=>{arguments[arguments.length]=(e,r)=>{if(e)return n(e);t(r)},arguments.length++,e.apply(this,arguments)}));e.apply(this,arguments)}),"name",{value:e.name})},fromPromise:function(e){return Object.defineProperty((function(){const t=arguments[arguments.length-1];if("function"!=typeof t)return e.apply(this,arguments);e.apply(this,arguments).then((e=>t(null,e)),t)}),"name",{value:e.name})}};!function(e){const t=yo.fromCallback,n=we,r=["access","appendFile","chmod","chown","close","copyFile","fchmod","fchown","fdatasync","fstat","fsync","ftruncate","futimes","lchown","lchmod","link","lstat","mkdir","mkdtemp","open","readFile","readdir","readlink","realpath","rename","rmdir","stat","symlink","truncate","unlink","utimes","writeFile"].filter((e=>"function"==typeof n[e]));Object.keys(n).forEach((t=>{"promises"!==t&&(e[t]=n[t])})),r.forEach((r=>{e[r]=t(n[r])})),e.exists=function(e,t){return"function"==typeof t?n.exists(e,t):new Promise((t=>n.exists(e,t)))},e.read=function(e,t,r,u,o,i){return"function"==typeof i?n.read(e,t,r,u,o,i):new Promise(((i,s)=>{n.read(e,t,r,u,o,((e,t,n)=>{if(e)return s(e);i({bytesRead:t,buffer:n})}))}))},e.write=function(e,t,...r){return"function"==typeof r[r.length-1]?n.write(e,t,...r):new Promise(((u,o)=>{n.write(e,t,...r,((e,t,n)=>{if(e)return o(e);u({bytesWritten:t,buffer:n})}))}))},"function"==typeof n.realpath.native&&(e.realpath.native=t(n.realpath.native))}(ho);const Co=p.default;function Fo(e){return(e=Co.normalize(Co.resolve(e)).split(Co.sep)).length>0?e[0]:null}const go=/[<>:"|?*]/;var Ao=function(e){const t=Fo(e);return e=e.replace(t,""),go.test(e)};const vo=we,So=p.default,wo=Ao,Oo=parseInt("0777",8);var bo=function e(t,n,r,u){if("function"==typeof n?(r=n,n={}):n&&"object"==typeof n||(n={mode:n}),"win32"===process.platform&&wo(t)){const e=new Error(t+" contains invalid WIN32 path characters.");return e.code="EINVAL",r(e)}let o=n.mode;const i=n.fs||vo;void 0===o&&(o=Oo&~process.umask()),u||(u=null),r=r||function(){},t=So.resolve(t),i.mkdir(t,o,(o=>{if(!o)return r(null,u=u||t);if("ENOENT"===o.code){if(So.dirname(t)===t)return r(o);e(So.dirname(t),n,((u,o)=>{u?r(u,o):e(t,n,r,o)}))}else i.stat(t,((e,t)=>{e||!t.isDirectory()?r(o,u):r(null,u)}))}))};const _o=we,Bo=p.default,Po=Ao,ko=parseInt("0777",8);var xo=function e(t,n,r){n&&"object"==typeof n||(n={mode:n});let u=n.mode;const o=n.fs||_o;if("win32"===process.platform&&Po(t)){const e=new Error(t+" contains invalid WIN32 path characters.");throw e.code="EINVAL",e}void 0===u&&(u=ko&~process.umask()),r||(r=null),t=Bo.resolve(t);try{o.mkdirSync(t,u),r=r||t}catch(u){if("ENOENT"===u.code){if(Bo.dirname(t)===t)throw u;r=e(Bo.dirname(t),n,r),e(t,n,r)}else{let e;try{e=o.statSync(t)}catch(e){throw u}if(!e.isDirectory())throw u}}return r};const No=(0,yo.fromCallback)(bo);var Io={mkdirs:No,mkdirsSync:xo,mkdirp:No,mkdirpSync:xo,ensureDir:No,ensureDirSync:xo};const To=we;E.default,p.default;var Ro=function(e,t,n,r){To.open(e,"r+",((e,u)=>{if(e)return r(e);To.futimes(u,t,n,(e=>{To.close(u,(t=>{r&&r(e||t)}))}))}))},Mo=function(e,t,n){const r=To.openSync(e,"r+");return To.futimesSync(r,t,n),To.closeSync(r)};const Lo=we,jo=p.default,$o=10,Ho=5,Jo=0,Go=process.versions.node.split("."),Vo=Number.parseInt(Go[0],10),Uo=Number.parseInt(Go[1],10),Wo=Number.parseInt(Go[2],10);function zo(){if(Vo>$o)return!0;if(Vo===$o){if(Uo>Ho)return!0;if(Uo===Ho&&Wo>=Jo)return!0}return!1}function Ko(e,t){const n=jo.resolve(e).split(jo.sep).filter((e=>e)),r=jo.resolve(t).split(jo.sep).filter((e=>e));return n.reduce(((e,t,n)=>e&&r[n]===t),!0)}function qo(e,t,n){return`Cannot ${n} '${e}' to a subdirectory of itself, '${t}'.`}var Yo,Xo,Zo={checkPaths:function(e,t,n,r){!function(e,t,n){zo()?Lo.stat(e,{bigint:!0},((e,r)=>{if(e)return n(e);Lo.stat(t,{bigint:!0},((e,t)=>e?"ENOENT"===e.code?n(null,{srcStat:r,destStat:null}):n(e):n(null,{srcStat:r,destStat:t})))})):Lo.stat(e,((e,r)=>{if(e)return n(e);Lo.stat(t,((e,t)=>e?"ENOENT"===e.code?n(null,{srcStat:r,destStat:null}):n(e):n(null,{srcStat:r,destStat:t})))}))}(e,t,((u,o)=>{if(u)return r(u);const{srcStat:i,destStat:s}=o;return s&&s.ino&&s.dev&&s.ino===i.ino&&s.dev===i.dev?r(new Error("Source and destination must not be the same.")):i.isDirectory()&&Ko(e,t)?r(new Error(qo(e,t,n))):r(null,{srcStat:i,destStat:s})}))},checkPathsSync:function(e,t,n){const{srcStat:r,destStat:u}=function(e,t){let n,r;n=zo()?Lo.statSync(e,{bigint:!0}):Lo.statSync(e);try{r=zo()?Lo.statSync(t,{bigint:!0}):Lo.statSync(t)}catch(e){if("ENOENT"===e.code)return{srcStat:n,destStat:null};throw e}return{srcStat:n,destStat:r}}(e,t);if(u&&u.ino&&u.dev&&u.ino===r.ino&&u.dev===r.dev)throw new Error("Source and destination must not be the same.");if(r.isDirectory()&&Ko(e,t))throw new Error(qo(e,t,n));return{srcStat:r,destStat:u}},checkParentPaths:function e(t,n,r,u,o){const i=jo.resolve(jo.dirname(t)),s=jo.resolve(jo.dirname(r));if(s===i||s===jo.parse(s).root)return o();zo()?Lo.stat(s,{bigint:!0},((i,c)=>i?"ENOENT"===i.code?o():o(i):c.ino&&c.dev&&c.ino===n.ino&&c.dev===n.dev?o(new Error(qo(t,r,u))):e(t,n,s,u,o))):Lo.stat(s,((i,c)=>i?"ENOENT"===i.code?o():o(i):c.ino&&c.dev&&c.ino===n.ino&&c.dev===n.dev?o(new Error(qo(t,r,u))):e(t,n,s,u,o)))},checkParentPathsSync:function e(t,n,r,u){const o=jo.resolve(jo.dirname(t)),i=jo.resolve(jo.dirname(r));if(i===o||i===jo.parse(i).root)return;let s;try{s=zo()?Lo.statSync(i,{bigint:!0}):Lo.statSync(i)}catch(e){if("ENOENT"===e.code)return;throw e}if(s.ino&&s.dev&&s.ino===n.ino&&s.dev===n.dev)throw new Error(qo(t,r,u));return e(t,n,i,u)},isSrcSubdir:Ko};const Qo=we,ei=p.default,ti=Io.mkdirsSync,ni=Mo,ri=Zo;function ui(e,t,n,r){if(!r.filter||r.filter(t,n))return function(e,t,n,r){const u=r.dereference?Qo.statSync:Qo.lstatSync,o=u(t);if(o.isDirectory())return function(e,t,n,r,u){if(!t)return function(e,t,n,r){return Qo.mkdirSync(n),ii(t,n,r),Qo.chmodSync(n,e.mode)}(e,n,r,u);if(t&&!t.isDirectory())throw new Error(`Cannot overwrite non-directory '${r}' with directory '${n}'.`);return ii(n,r,u)}(o,e,t,n,r);if(o.isFile()||o.isCharacterDevice()||o.isBlockDevice())return function(e,t,n,r,u){return t?function(e,t,n,r){if(r.overwrite)return Qo.unlinkSync(n),oi(e,t,n,r);if(r.errorOnExist)throw new Error(`'${n}' already exists`)}(e,n,r,u):oi(e,n,r,u)}(o,e,t,n,r);if(o.isSymbolicLink())return function(e,t,n,r){let u=Qo.readlinkSync(t);r.dereference&&(u=ei.resolve(process.cwd(),u));if(e){let e;try{e=Qo.readlinkSync(n)}catch(e){if("EINVAL"===e.code||"UNKNOWN"===e.code)return Qo.symlinkSync(u,n);throw e}if(r.dereference&&(e=ei.resolve(process.cwd(),e)),ri.isSrcSubdir(u,e))throw new Error(`Cannot copy '${u}' to a subdirectory of itself, '${e}'.`);if(Qo.statSync(n).isDirectory()&&ri.isSrcSubdir(e,u))throw new Error(`Cannot overwrite '${e}' with '${u}'.`);return function(e,t){return Qo.unlinkSync(t),Qo.symlinkSync(e,t)}(u,n)}return Qo.symlinkSync(u,n)}(e,t,n,r)}(e,t,n,r)}function oi(e,t,n,r){return"function"==typeof Qo.copyFileSync?(Qo.copyFileSync(t,n),Qo.chmodSync(n,e.mode),r.preserveTimestamps?ni(n,e.atime,e.mtime):void 0):function(e,t,n,r){const u=65536,o=(Xo?Yo:(Xo=1,Yo=function(e){if("function"==typeof Buffer.allocUnsafe)try{return Buffer.allocUnsafe(e)}catch(t){return new Buffer(e)}return new Buffer(e)}))(u),i=Qo.openSync(t,"r"),s=Qo.openSync(n,"w",e.mode);let c=0;for(;cfunction(e,t,n,r){const u=ei.join(t,e),o=ei.join(n,e),{destStat:i}=ri.checkPathsSync(u,o,"copy");return ui(i,u,o,r)}(r,e,t,n)))}var si=function(e,t,n){"function"==typeof n&&(n={filter:n}),(n=n||{}).clobber=!("clobber"in n)||!!n.clobber,n.overwrite="overwrite"in n?!!n.overwrite:n.clobber,n.preserveTimestamps&&"ia32"===process.arch&&console.warn("fs-extra: Using the preserveTimestamps option in 32-bit node is not recommended;\n\n see https://github.com/jprichardson/node-fs-extra/issues/269");const{srcStat:r,destStat:u}=ri.checkPathsSync(e,t,"copy");return ri.checkParentPathsSync(e,r,t,"copy"),function(e,t,n,r){if(r.filter&&!r.filter(t,n))return;const u=ei.dirname(n);Qo.existsSync(u)||ti(u);return ui(e,t,n,r)}(u,e,t,n)},ci={copySync:si};const ai=yo.fromPromise,li=ho;var fi={pathExists:ai((function(e){return li.access(e).then((()=>!0)).catch((()=>!1))})),pathExistsSync:li.existsSync};const di=we,Di=p.default,pi=Io.mkdirs,Ei=fi.pathExists,mi=Ro,hi=Zo;function yi(e,t,n,r,u){const o=Di.dirname(n);Ei(o,((i,s)=>i?u(i):s?Fi(e,t,n,r,u):void pi(o,(o=>o?u(o):Fi(e,t,n,r,u)))))}function Ci(e,t,n,r,u,o){Promise.resolve(u.filter(n,r)).then((i=>i?e(t,n,r,u,o):o()),(e=>o(e)))}function Fi(e,t,n,r,u){return r.filter?Ci(gi,e,t,n,r,u):gi(e,t,n,r,u)}function gi(e,t,n,r,u){(r.dereference?di.stat:di.lstat)(t,((o,i)=>o?u(o):i.isDirectory()?function(e,t,n,r,u,o){if(!t)return function(e,t,n,r,u){di.mkdir(n,(o=>{if(o)return u(o);Si(t,n,r,(t=>t?u(t):di.chmod(n,e.mode,u)))}))}(e,n,r,u,o);if(t&&!t.isDirectory())return o(new Error(`Cannot overwrite non-directory '${r}' with directory '${n}'.`));return Si(n,r,u,o)}(i,e,t,n,r,u):i.isFile()||i.isCharacterDevice()||i.isBlockDevice()?function(e,t,n,r,u,o){return t?function(e,t,n,r,u){if(!r.overwrite)return r.errorOnExist?u(new Error(`'${n}' already exists`)):u();di.unlink(n,(o=>o?u(o):Ai(e,t,n,r,u)))}(e,n,r,u,o):Ai(e,n,r,u,o)}(i,e,t,n,r,u):i.isSymbolicLink()?function(e,t,n,r,u){di.readlink(t,((t,o)=>t?u(t):(r.dereference&&(o=Di.resolve(process.cwd(),o)),e?void di.readlink(n,((t,i)=>t?"EINVAL"===t.code||"UNKNOWN"===t.code?di.symlink(o,n,u):u(t):(r.dereference&&(i=Di.resolve(process.cwd(),i)),hi.isSrcSubdir(o,i)?u(new Error(`Cannot copy '${o}' to a subdirectory of itself, '${i}'.`)):e.isDirectory()&&hi.isSrcSubdir(i,o)?u(new Error(`Cannot overwrite '${i}' with '${o}'.`)):function(e,t,n){di.unlink(t,(r=>r?n(r):di.symlink(e,t,n)))}(o,n,u)))):di.symlink(o,n,u))))}(e,t,n,r,u):void 0))}function Ai(e,t,n,r,u){return"function"==typeof di.copyFile?di.copyFile(t,n,(t=>t?u(t):vi(e,n,r,u))):function(e,t,n,r,u){const o=di.createReadStream(t);o.on("error",(e=>u(e))).once("open",(()=>{const t=di.createWriteStream(n,{mode:e.mode});t.on("error",(e=>u(e))).on("open",(()=>o.pipe(t))).once("close",(()=>vi(e,n,r,u)))}))}(e,t,n,r,u)}function vi(e,t,n,r){di.chmod(t,e.mode,(u=>u?r(u):n.preserveTimestamps?mi(t,e.atime,e.mtime,r):r()))}function Si(e,t,n,r){di.readdir(e,((u,o)=>u?r(u):wi(o,e,t,n,r)))}function wi(e,t,n,r,u){const o=e.pop();return o?function(e,t,n,r,u,o){const i=Di.join(n,t),s=Di.join(r,t);hi.checkPaths(i,s,"copy",((t,c)=>{if(t)return o(t);const{destStat:a}=c;Fi(a,i,s,u,(t=>t?o(t):wi(e,n,r,u,o)))}))}(e,o,t,n,r,u):u()}var Oi=function(e,t,n,r){"function"!=typeof n||r?"function"==typeof n&&(n={filter:n}):(r=n,n={}),r=r||function(){},(n=n||{}).clobber=!("clobber"in n)||!!n.clobber,n.overwrite="overwrite"in n?!!n.overwrite:n.clobber,n.preserveTimestamps&&"ia32"===process.arch&&console.warn("fs-extra: Using the preserveTimestamps option in 32-bit node is not recommended;\n\n see https://github.com/jprichardson/node-fs-extra/issues/269"),hi.checkPaths(e,t,"copy",((u,o)=>{if(u)return r(u);const{srcStat:i,destStat:s}=o;hi.checkParentPaths(e,i,t,"copy",(u=>u?r(u):n.filter?Ci(yi,s,e,t,n,r):yi(s,e,t,n,r)))}))};var bi={copy:(0,yo.fromCallback)(Oi)};const _i=we,Bi=p.default,Pi=g.default,ki="win32"===process.platform;function xi(e){["unlink","chmod","stat","lstat","rmdir","readdir"].forEach((t=>{e[t]=e[t]||_i[t],e[t+="Sync"]=e[t]||_i[t]})),e.maxBusyTries=e.maxBusyTries||3}function Ni(e,t,n){let r=0;"function"==typeof t&&(n=t,t={}),Pi(e,"rimraf: missing path"),Pi.strictEqual(typeof e,"string","rimraf: path should be a string"),Pi.strictEqual(typeof n,"function","rimraf: callback function required"),Pi(t,"rimraf: invalid options argument provided"),Pi.strictEqual(typeof t,"object","rimraf: options should be object"),xi(t),Ii(e,t,(function u(o){if(o){if(("EBUSY"===o.code||"ENOTEMPTY"===o.code||"EPERM"===o.code)&&rIi(e,t,u)),100*r)}"ENOENT"===o.code&&(o=null)}n(o)}))}function Ii(e,t,n){Pi(e),Pi(t),Pi("function"==typeof n),t.lstat(e,((r,u)=>r&&"ENOENT"===r.code?n(null):r&&"EPERM"===r.code&&ki?Ti(e,t,r,n):u&&u.isDirectory()?Mi(e,t,r,n):void t.unlink(e,(r=>{if(r){if("ENOENT"===r.code)return n(null);if("EPERM"===r.code)return ki?Ti(e,t,r,n):Mi(e,t,r,n);if("EISDIR"===r.code)return Mi(e,t,r,n)}return n(r)}))))}function Ti(e,t,n,r){Pi(e),Pi(t),Pi("function"==typeof r),n&&Pi(n instanceof Error),t.chmod(e,438,(u=>{u?r("ENOENT"===u.code?null:n):t.stat(e,((u,o)=>{u?r("ENOENT"===u.code?null:n):o.isDirectory()?Mi(e,t,n,r):t.unlink(e,r)}))}))}function Ri(e,t,n){let r;Pi(e),Pi(t),n&&Pi(n instanceof Error);try{t.chmodSync(e,438)}catch(e){if("ENOENT"===e.code)return;throw n}try{r=t.statSync(e)}catch(e){if("ENOENT"===e.code)return;throw n}r.isDirectory()?ji(e,t,n):t.unlinkSync(e)}function Mi(e,t,n,r){Pi(e),Pi(t),n&&Pi(n instanceof Error),Pi("function"==typeof r),t.rmdir(e,(u=>{!u||"ENOTEMPTY"!==u.code&&"EEXIST"!==u.code&&"EPERM"!==u.code?u&&"ENOTDIR"===u.code?r(n):r(u):function(e,t,n){Pi(e),Pi(t),Pi("function"==typeof n),t.readdir(e,((r,u)=>{if(r)return n(r);let o,i=u.length;if(0===i)return t.rmdir(e,n);u.forEach((r=>{Ni(Bi.join(e,r),t,(r=>{if(!o)return r?n(o=r):void(0==--i&&t.rmdir(e,n))}))}))}))}(e,t,r)}))}function Li(e,t){let n;xi(t=t||{}),Pi(e,"rimraf: missing path"),Pi.strictEqual(typeof e,"string","rimraf: path should be a string"),Pi(t,"rimraf: missing options"),Pi.strictEqual(typeof t,"object","rimraf: options should be object");try{n=t.lstatSync(e)}catch(n){if("ENOENT"===n.code)return;"EPERM"===n.code&&ki&&Ri(e,t,n)}try{n&&n.isDirectory()?ji(e,t,null):t.unlinkSync(e)}catch(n){if("ENOENT"===n.code)return;if("EPERM"===n.code)return ki?Ri(e,t,n):ji(e,t,n);if("EISDIR"!==n.code)throw n;ji(e,t,n)}}function ji(e,t,n){Pi(e),Pi(t),n&&Pi(n instanceof Error);try{t.rmdirSync(e)}catch(r){if("ENOTDIR"===r.code)throw n;if("ENOTEMPTY"===r.code||"EEXIST"===r.code||"EPERM"===r.code)!function(e,t){if(Pi(e),Pi(t),t.readdirSync(e).forEach((n=>Li(Bi.join(e,n),t))),!ki){return t.rmdirSync(e,t)}{const n=Date.now();do{try{return t.rmdirSync(e,t)}catch(e){}}while(Date.now()-n<500)}}(e,t);else if("ENOENT"!==r.code)throw r}}var $i=Ni;Ni.sync=Li;const Hi=$i;var Ji={remove:(0,yo.fromCallback)(Hi),removeSync:Hi.sync};const Gi=yo.fromCallback,Vi=we,Ui=p.default,Wi=Io,zi=Ji,Ki=Gi((function(e,t){t=t||function(){},Vi.readdir(e,((n,r)=>{if(n)return Wi.mkdirs(e,t);r=r.map((t=>Ui.join(e,t))),function e(){const n=r.pop();if(!n)return t();zi.remove(n,(n=>{if(n)return t(n);e()}))}()}))}));function qi(e){let t;try{t=Vi.readdirSync(e)}catch(t){return Wi.mkdirsSync(e)}t.forEach((t=>{t=Ui.join(e,t),zi.removeSync(t)}))}var Yi={emptyDirSync:qi,emptydirSync:qi,emptyDir:Ki,emptydir:Ki};const Xi=yo.fromCallback,Zi=p.default,Qi=we,es=Io,ts=fi.pathExists;var ns={createFile:Xi((function(e,t){function n(){Qi.writeFile(e,"",(e=>{if(e)return t(e);t()}))}Qi.stat(e,((r,u)=>{if(!r&&u.isFile())return t();const o=Zi.dirname(e);ts(o,((e,r)=>e?t(e):r?n():void es.mkdirs(o,(e=>{if(e)return t(e);n()}))))}))})),createFileSync:function(e){let t;try{t=Qi.statSync(e)}catch(e){}if(t&&t.isFile())return;const n=Zi.dirname(e);Qi.existsSync(n)||es.mkdirsSync(n),Qi.writeFileSync(e,"")}};const rs=yo.fromCallback,us=p.default,os=we,is=Io,ss=fi.pathExists;var cs={createLink:rs((function(e,t,n){function r(e,t){os.link(e,t,(e=>{if(e)return n(e);n(null)}))}ss(t,((u,o)=>u?n(u):o?n(null):void os.lstat(e,(u=>{if(u)return u.message=u.message.replace("lstat","ensureLink"),n(u);const o=us.dirname(t);ss(o,((u,i)=>u?n(u):i?r(e,t):void is.mkdirs(o,(u=>{if(u)return n(u);r(e,t)}))))}))))})),createLinkSync:function(e,t){if(os.existsSync(t))return;try{os.lstatSync(e)}catch(e){throw e.message=e.message.replace("lstat","ensureLink"),e}const n=us.dirname(t);return os.existsSync(n)||is.mkdirsSync(n),os.linkSync(e,t)}};const as=p.default,ls=we,fs=fi.pathExists;var ds={symlinkPaths:function(e,t,n){if(as.isAbsolute(e))return ls.lstat(e,(t=>t?(t.message=t.message.replace("lstat","ensureSymlink"),n(t)):n(null,{toCwd:e,toDst:e})));{const r=as.dirname(t),u=as.join(r,e);return fs(u,((t,o)=>t?n(t):o?n(null,{toCwd:u,toDst:e}):ls.lstat(e,(t=>t?(t.message=t.message.replace("lstat","ensureSymlink"),n(t)):n(null,{toCwd:e,toDst:as.relative(r,e)})))))}},symlinkPathsSync:function(e,t){let n;if(as.isAbsolute(e)){if(n=ls.existsSync(e),!n)throw new Error("absolute srcpath does not exist");return{toCwd:e,toDst:e}}{const r=as.dirname(t),u=as.join(r,e);if(n=ls.existsSync(u),n)return{toCwd:u,toDst:e};if(n=ls.existsSync(e),!n)throw new Error("relative srcpath does not exist");return{toCwd:e,toDst:as.relative(r,e)}}}};const Ds=we;var ps={symlinkType:function(e,t,n){if(n="function"==typeof t?t:n,t="function"!=typeof t&&t)return n(null,t);Ds.lstat(e,((e,r)=>{if(e)return n(null,"file");t=r&&r.isDirectory()?"dir":"file",n(null,t)}))},symlinkTypeSync:function(e,t){let n;if(t)return t;try{n=Ds.lstatSync(e)}catch(e){return"file"}return n&&n.isDirectory()?"dir":"file"}};const Es=yo.fromCallback,ms=p.default,hs=we,ys=Io.mkdirs,Cs=Io.mkdirsSync,Fs=ds.symlinkPaths,gs=ds.symlinkPathsSync,As=ps.symlinkType,vs=ps.symlinkTypeSync,Ss=fi.pathExists;var ws={createSymlink:Es((function(e,t,n,r){r="function"==typeof n?n:r,n="function"!=typeof n&&n,Ss(t,((u,o)=>u?r(u):o?r(null):void Fs(e,t,((u,o)=>{if(u)return r(u);e=o.toDst,As(o.toCwd,n,((n,u)=>{if(n)return r(n);const o=ms.dirname(t);Ss(o,((n,i)=>n?r(n):i?hs.symlink(e,t,u,r):void ys(o,(n=>{if(n)return r(n);hs.symlink(e,t,u,r)}))))}))}))))})),createSymlinkSync:function(e,t,n){if(hs.existsSync(t))return;const r=gs(e,t);e=r.toDst,n=vs(r.toCwd,n);const u=ms.dirname(t);return hs.existsSync(u)||Cs(u),hs.symlinkSync(e,t,n)}};var Os,bs={createFile:ns.createFile,createFileSync:ns.createFileSync,ensureFile:ns.createFile,ensureFileSync:ns.createFileSync,createLink:cs.createLink,createLinkSync:cs.createLinkSync,ensureLink:cs.createLink,ensureLinkSync:cs.createLinkSync,createSymlink:ws.createSymlink,createSymlinkSync:ws.createSymlinkSync,ensureSymlink:ws.createSymlink,ensureSymlinkSync:ws.createSymlinkSync};try{Os=we}catch(e){Os=D.default}function _s(e,t){var n,r="\n";return"object"==typeof t&&null!==t&&(t.spaces&&(n=t.spaces),t.EOL&&(r=t.EOL)),JSON.stringify(e,t?t.replacer:null,n).replace(/\n/g,r)+r}function Bs(e){return Buffer.isBuffer(e)&&(e=e.toString("utf8")),e=e.replace(/^\uFEFF/,"")}var Ps={readFile:function(e,t,n){null==n&&(n=t,t={}),"string"==typeof t&&(t={encoding:t});var r=(t=t||{}).fs||Os,u=!0;"throws"in t&&(u=t.throws),r.readFile(e,t,(function(r,o){if(r)return n(r);var i;o=Bs(o);try{i=JSON.parse(o,t?t.reviver:null)}catch(t){return u?(t.message=e+": "+t.message,n(t)):n(null,null)}n(null,i)}))},readFileSync:function(e,t){"string"==typeof(t=t||{})&&(t={encoding:t});var n=t.fs||Os,r=!0;"throws"in t&&(r=t.throws);try{var u=n.readFileSync(e,t);return u=Bs(u),JSON.parse(u,t.reviver)}catch(t){if(r)throw t.message=e+": "+t.message,t;return null}},writeFile:function(e,t,n,r){null==r&&(r=n,n={});var u=(n=n||{}).fs||Os,o="";try{o=_s(t,n)}catch(e){return void(r&&r(e,null))}u.writeFile(e,o,n,r)},writeFileSync:function(e,t,n){var r=(n=n||{}).fs||Os,u=_s(t,n);return r.writeFileSync(e,u,n)}},ks=Ps;const xs=yo.fromCallback,Ns=ks;var Is={readJson:xs(Ns.readFile),readJsonSync:Ns.readFileSync,writeJson:xs(Ns.writeFile),writeJsonSync:Ns.writeFileSync};const Ts=p.default,Rs=Io,Ms=fi.pathExists,Ls=Is;var js=function(e,t,n,r){"function"==typeof n&&(r=n,n={});const u=Ts.dirname(e);Ms(u,((o,i)=>o?r(o):i?Ls.writeJson(e,t,n,r):void Rs.mkdirs(u,(u=>{if(u)return r(u);Ls.writeJson(e,t,n,r)}))))};const $s=we,Hs=p.default,Js=Io,Gs=Is;var Vs=function(e,t,n){const r=Hs.dirname(e);$s.existsSync(r)||Js.mkdirsSync(r),Gs.writeJsonSync(e,t,n)};const Us=yo.fromCallback,Ws=Is;Ws.outputJson=Us(js),Ws.outputJsonSync=Vs,Ws.outputJSON=Ws.outputJson,Ws.outputJSONSync=Ws.outputJsonSync,Ws.writeJSON=Ws.writeJson,Ws.writeJSONSync=Ws.writeJsonSync,Ws.readJSON=Ws.readJson,Ws.readJSONSync=Ws.readJsonSync;var zs=Ws;const Ks=we,qs=p.default,Ys=ci.copySync,Xs=Ji.removeSync,Zs=Io.mkdirpSync,Qs=Zo;function ec(e,t,n){try{Ks.renameSync(e,t)}catch(r){if("EXDEV"!==r.code)throw r;return function(e,t,n){const r={overwrite:n,errorOnExist:!0};return Ys(e,t,r),Xs(e)}(e,t,n)}}var tc=function(e,t,n){const r=(n=n||{}).overwrite||n.clobber||!1,{srcStat:u}=Qs.checkPathsSync(e,t,"move");return Qs.checkParentPathsSync(e,u,t,"move"),Zs(qs.dirname(t)),function(e,t,n){if(n)return Xs(t),ec(e,t,n);if(Ks.existsSync(t))throw new Error("dest already exists.");return ec(e,t,n)}(e,t,r)},nc={moveSync:tc};const rc=we,uc=p.default,oc=bi.copy,ic=Ji.remove,sc=Io.mkdirp,cc=fi.pathExists,ac=Zo;function lc(e,t,n,r){rc.rename(e,t,(u=>u?"EXDEV"!==u.code?r(u):function(e,t,n,r){const u={overwrite:n,errorOnExist:!0};oc(e,t,u,(t=>t?r(t):ic(e,r)))}(e,t,n,r):r()))}var fc=function(e,t,n,r){"function"==typeof n&&(r=n,n={});const u=n.overwrite||n.clobber||!1;ac.checkPaths(e,t,"move",((n,o)=>{if(n)return r(n);const{srcStat:i}=o;ac.checkParentPaths(e,i,t,"move",(n=>{if(n)return r(n);sc(uc.dirname(t),(n=>n?r(n):function(e,t,n,r){if(n)return ic(t,(u=>u?r(u):lc(e,t,n,r)));cc(t,((u,o)=>u?r(u):o?r(new Error("dest already exists.")):lc(e,t,n,r)))}(e,t,u,r)))}))}))};var dc={move:(0,yo.fromCallback)(fc)};const Dc=yo.fromCallback,pc=we,Ec=p.default,mc=Io,hc=fi.pathExists;var yc={outputFile:Dc((function(e,t,n,r){"function"==typeof n&&(r=n,n="utf8");const u=Ec.dirname(e);hc(u,((o,i)=>o?r(o):i?pc.writeFile(e,t,n,r):void mc.mkdirs(u,(u=>{if(u)return r(u);pc.writeFile(e,t,n,r)}))))})),outputFileSync:function(e,...t){const n=Ec.dirname(e);if(pc.existsSync(n))return pc.writeFileSync(e,...t);mc.mkdirsSync(n),pc.writeFileSync(e,...t)}};!function(e){e.exports=Object.assign({},ho,ci,bi,Yi,bs,zs,Io,nc,dc,yc,fi,Ji);const t=D.default;Object.getOwnPropertyDescriptor(t,"promises")&&Object.defineProperty(e.exports,"promises",{get:()=>t.promises})}(mo);const Cc=Nr.exports("streamroller:fileNameFormatter"),Fc=p.default;const gc=Nr.exports("streamroller:fileNameParser"),Ac=nu.exports;const vc=Nr.exports("streamroller:moveAndMaybeCompressFile"),Sc=mo.exports,wc=v.default;var Oc=async(e,t,n)=>{if(n=function(e){const t={mode:parseInt("0600",8),compress:!1},n=Object.assign({},t,e);return vc(`_parseOption: moveAndMaybeCompressFile called with option=${JSON.stringify(n)}`),n}(n),e!==t){if(await Sc.pathExists(e))if(vc(`moveAndMaybeCompressFile: moving file from ${e} to ${t} ${n.compress?"with":"without"} compress`),n.compress)await new Promise(((r,u)=>{let o=!1;const i=Sc.createWriteStream(t,{mode:n.mode,flags:"wx"}).on("open",(()=>{o=!0;const t=Sc.createReadStream(e).on("open",(()=>{t.pipe(wc.createGzip()).pipe(i)})).on("error",(t=>{vc(`moveAndMaybeCompressFile: error reading ${e}`,t),i.destroy(t)}))})).on("finish",(()=>{vc(`moveAndMaybeCompressFile: finished compressing ${t}, deleting ${e}`),Sc.unlink(e).then(r).catch((t=>{vc(`moveAndMaybeCompressFile: error deleting ${e}, truncating instead`,t),Sc.truncate(e).then(r).catch((t=>{vc(`moveAndMaybeCompressFile: error truncating ${e}`,t),u(t)}))}))})).on("error",(e=>{o?(vc(`moveAndMaybeCompressFile: error writing ${t}, deleting`,e),Sc.unlink(t).then((()=>{u(e)})).catch((e=>{vc(`moveAndMaybeCompressFile: error deleting ${t}`,e),u(e)}))):(vc(`moveAndMaybeCompressFile: error creating ${t}`,e),u(e))}))})).catch((()=>{}));else{vc(`moveAndMaybeCompressFile: renaming ${e} to ${t}`);try{await Sc.move(e,t,{overwrite:!0})}catch(n){if(vc(`moveAndMaybeCompressFile: error renaming ${e} to ${t}`,n),"ENOENT"!==n.code){vc("moveAndMaybeCompressFile: trying copy+truncate instead");try{await Sc.copy(e,t,{overwrite:!0}),await Sc.truncate(e)}catch(e){vc("moveAndMaybeCompressFile: error copy+truncate",e)}}}}}else vc("moveAndMaybeCompressFile: source and target are the same, not doing anything")};const bc=Nr.exports("streamroller:RollingFileWriteStream"),_c=mo.exports,Bc=p.default,Pc=E.default,kc=()=>new Date,xc=nu.exports,{Writable:Nc}=C.default,Ic=({file:e,keepFileExt:t,needsIndex:n,alwaysIncludeDate:r,compress:u,fileNameSep:o})=>{let i=o||".";const s=Fc.join(e.dir,e.name),c=t=>t+e.ext,a=(e,t,r)=>!n&&r||!t?e:e+i+t,l=(e,t,n)=>(t>0||r)&&n?e+i+n:e,f=(e,t)=>t&&u?e+".gz":e,d=t?[l,a,c,f]:[c,l,a,f];return({date:e,index:t})=>(Cc(`_formatFileName: date=${e}, index=${t}`),d.reduce(((n,r)=>r(n,t,e)),s))},Tc=({file:e,keepFileExt:t,pattern:n,fileNameSep:r})=>{let u=r||".";const o="__NOT_MATCHING__";let i=[(e,t)=>e.endsWith(".gz")?(gc("it is gzipped"),t.isCompressed=!0,e.slice(0,-1*".gz".length)):e,t?t=>t.startsWith(e.name)&&t.endsWith(e.ext)?(gc("it starts and ends with the right things"),t.slice(e.name.length+1,-1*e.ext.length)):o:t=>t.startsWith(e.base)?(gc("it starts with the right things"),t.slice(e.base.length+1)):o,n?(e,t)=>{const r=e.split(u);let o=r[r.length-1];gc("items: ",r,", indexStr: ",o);let i=e;void 0!==o&&o.match(/^\d+$/)?(i=e.slice(0,-1*(o.length+1)),gc(`dateStr is ${i}`),n&&!i&&(i=o,o="0")):o="0";try{const r=Ac.parse(n,i,new Date(0,0));return Ac.asString(n,r)!==i?e:(t.index=parseInt(o,10),t.date=i,t.timestamp=r.getTime(),"")}catch(t){return gc(`Problem parsing ${i} as ${n}, error was: `,t),e}}:(e,t)=>e.match(/^\d+$/)?(gc("it has an index"),t.index=parseInt(e,10),""):e];return e=>{let t={filename:e,index:0,isCompressed:!1};return i.reduce(((e,n)=>n(e,t)),e)?null:t}},Rc=Oc;var Mc=class extends Nc{constructor(e,t){if(bc(`constructor: creating RollingFileWriteStream. path=${e}`),"string"!=typeof e||0===e.length)throw new Error(`Invalid filename: ${e}`);if(e.endsWith(Bc.sep))throw new Error(`Filename is a directory: ${e}`);0===e.indexOf(`~${Bc.sep}`)&&(e=e.replace("~",Pc.homedir())),super(t),this.options=this._parseOption(t),this.fileObject=Bc.parse(e),""===this.fileObject.dir&&(this.fileObject=Bc.parse(Bc.join(process.cwd(),e))),this.fileFormatter=Ic({file:this.fileObject,alwaysIncludeDate:this.options.alwaysIncludePattern,needsIndex:this.options.maxSize 0`)}else delete n.maxSize;if(n.numBackups||0===n.numBackups){if(n.numBackups<0)throw new Error(`options.numBackups (${n.numBackups}) should be >= 0`);if(n.numBackups>=Number.MAX_SAFE_INTEGER)throw new Error(`options.numBackups (${n.numBackups}) should be < Number.MAX_SAFE_INTEGER`);n.numToKeep=n.numBackups+1}else if(n.numToKeep<=0)throw new Error(`options.numToKeep (${n.numToKeep}) should be > 0`);return bc(`_parseOption: creating stream with option=${JSON.stringify(n)}`),n}_final(e){this.currentFileStream.end("",this.options.encoding,e)}_write(e,t,n){this._shouldRoll().then((()=>{bc(`_write: writing chunk. file=${this.currentFileStream.path} state=${JSON.stringify(this.state)} chunk=${e}`),this.currentFileStream.write(e,t,(t=>{this.state.currentSize+=e.length,n(t)}))}))}async _shouldRoll(){(this._dateChanged()||this._tooBig())&&(bc(`_shouldRoll: rolling because dateChanged? ${this._dateChanged()} or tooBig? ${this._tooBig()}`),await this._roll())}_dateChanged(){return this.state.currentDate&&this.state.currentDate!==xc(this.options.pattern,kc())}_tooBig(){return this.state.currentSize>=this.options.maxSize}_roll(){return bc("_roll: closing the current stream"),new Promise(((e,t)=>{this.currentFileStream.end("",this.options.encoding,(()=>{this._moveOldFiles().then(e).catch(t)}))}))}async _moveOldFiles(){const e=await this._getExistingFiles();for(let t=(this.state.currentDate?e.filter((e=>e.date===this.state.currentDate)):e).length;t>=0;t--){bc(`_moveOldFiles: i = ${t}`);const e=this.fileFormatter({date:this.state.currentDate,index:t}),n=this.fileFormatter({date:this.state.currentDate,index:t+1}),r={compress:this.options.compress&&0===t,mode:this.options.mode};await Rc(e,n,r)}this.state.currentSize=0,this.state.currentDate=this.state.currentDate?xc(this.options.pattern,kc()):null,bc(`_moveOldFiles: finished rolling files. state=${JSON.stringify(this.state)}`),this._renewWriteStream(),await new Promise(((e,t)=>{this.currentFileStream.write("","utf8",(()=>{this._clean().then(e).catch(t)}))}))}async _getExistingFiles(){const e=await _c.readdir(this.fileObject.dir).catch((()=>[]));bc(`_getExistingFiles: files=${e}`);const t=e.map((e=>this.fileNameParser(e))).filter((e=>e)),n=e=>(e.timestamp?e.timestamp:kc().getTime())-e.index;return t.sort(((e,t)=>n(e)-n(t))),t}_renewWriteStream(){const e=this.fileFormatter({date:this.state.currentDate,index:0}),t=e=>{try{return _c.mkdirSync(e,{recursive:!0})}catch(n){if("ENOENT"===n.code)return t(Bc.dirname(e)),t(e);if("EEXIST"!==n.code&&"EROFS"!==n.code)throw n;try{if(_c.statSync(e).isDirectory())return e;throw n}catch(e){throw n}}};t(this.fileObject.dir);const n={flags:this.options.flags,encoding:this.options.encoding,mode:this.options.mode};var r,u;_c.appendFileSync(e,"",(r={...n},u="flags",r["flag"]=r[u],delete r[u],r)),this.currentFileStream=_c.createWriteStream(e,n),this.currentFileStream.on("error",(e=>{this.emit("error",e)}))}async _clean(){const e=await this._getExistingFiles();if(bc(`_clean: numToKeep = ${this.options.numToKeep}, existingFiles = ${e.length}`),bc("_clean: existing files are: ",e),this._tooManyFiles(e.length)){const n=e.slice(0,e.length-this.options.numToKeep).map((e=>Bc.format({dir:this.fileObject.dir,base:e.filename})));await(t=n,bc(`deleteFiles: files to delete: ${t}`),Promise.all(t.map((e=>_c.unlink(e).catch((t=>{bc(`deleteFiles: error when unlinking ${e}, ignoring. Error was ${t}`)}))))))}var t}_tooManyFiles(e){return this.options.numToKeep>0&&e>this.options.numToKeep}};const Lc=Mc;var jc=class extends Lc{constructor(e,t,n,r){r||(r={}),t&&(r.maxSize=t),r.numBackups||0===r.numBackups||(n||0===n||(n=1),r.numBackups=n),super(e,r),this.backups=r.numBackups,this.size=this.options.maxSize}get theStream(){return this.currentFileStream}};const $c=Mc;var Hc={RollingFileWriteStream:Mc,RollingFileStream:jc,DateRollingFileStream:class extends $c{constructor(e,t,n){t&&"object"==typeof t&&(n=t,t=null),n||(n={}),t||(t="yyyy-MM-dd"),n.pattern=t,n.numBackups||0===n.numBackups?n.daysToKeep=n.numBackups:(n.daysToKeep||0===n.daysToKeep?process.emitWarning("options.daysToKeep is deprecated due to the confusion it causes when used together with file size rolling. Please use options.numBackups instead.","DeprecationWarning","streamroller-DEP0001"):n.daysToKeep=1,n.numBackups=n.daysToKeep),super(e,n),this.mode=this.options.mode}get theStream(){return this.currentFileStream}}};const Jc=Nr.exports("log4js:file"),Gc=p.default,Vc=Hc,Uc=E.default.EOL;let Wc=!1;const zc=new Set;function Kc(){zc.forEach((e=>{e.sighupHandler()}))}function qc(e,t,n,r){const u=new Vc.RollingFileStream(e,t,n,r);return u.on("error",(t=>{console.error("log4js.fileAppender - Writing to file %s, error happened ",e,t)})),u.on("drain",(()=>{process.emit("log4js:pause",!1)})),u}Eo.configure=function(e,t){let n=t.basicLayout;return e.layout&&(n=t.layout(e.layout.type,e.layout)),e.mode=e.mode||384,function(e,t,n,r,u,o){e=Gc.normalize(e),Jc("Creating file appender (",e,", ",n,", ",r=r||0===r?r:5,", ",u,", ",o,")");let i=qc(e,n,r,u);const s=function(e){if(i.writable){if(!0===u.removeColor){const t=/\x1b[[0-9;]*m/g;e.data=e.data.map((e=>"string"==typeof e?e.replace(t,""):e))}i.write(t(e,o)+Uc,"utf8")||process.emit("log4js:pause",!0)}};return s.reopen=function(){i.end((()=>{i=qc(e,n,r,u)}))},s.sighupHandler=function(){Jc("SIGHUP handler called."),s.reopen()},s.shutdown=function(e){zc.delete(s),0===zc.size&&Wc&&(process.removeListener("SIGHUP",Kc),Wc=!1),i.end("","utf-8",e)},zc.add(s),Wc||(process.on("SIGHUP",Kc),Wc=!0),s}(e.filename,n,e.maxLogSize,e.backups,e,e.timezoneOffset)};var Yc={};const Xc=Hc,Zc=E.default.EOL;function Qc(e,t,n,r,u){r.maxSize=r.maxLogSize;const o=function(e,t,n){const r=new Xc.DateRollingFileStream(e,t,n);return r.on("error",(t=>{console.error("log4js.dateFileAppender - Writing to file %s, error happened ",e,t)})),r.on("drain",(()=>{process.emit("log4js:pause",!1)})),r}(e,t,r),i=function(e){o.writable&&(o.write(n(e,u)+Zc,"utf8")||process.emit("log4js:pause",!0))};return i.shutdown=function(e){o.end("","utf-8",e)},i}Yc.configure=function(e,t){let n=t.basicLayout;return e.layout&&(n=t.layout(e.layout.type,e.layout)),e.alwaysIncludePattern||(e.alwaysIncludePattern=!1),e.mode=e.mode||384,Qc(e.filename,e.pattern,n,e,e.timezoneOffset)};var ea={};const ta=Nr.exports("log4js:fileSync"),na=p.default,ra=D.default,ua=E.default.EOL||"\n";function oa(e,t){if(ra.existsSync(e))return;const n=ra.openSync(e,t.flags,t.mode);ra.closeSync(n)}class ia{constructor(e,t,n,r){ta("In RollingFileStream"),function(){if(!e||!t||t<=0)throw new Error("You must specify a filename and file size")}(),this.filename=e,this.size=t,this.backups=n,this.options=r,this.currentSize=0,this.currentSize=function(e){let t=0;try{t=ra.statSync(e).size}catch(t){oa(e,r)}return t}(this.filename)}shouldRoll(){return ta("should roll with current size %d, and max size %d",this.currentSize,this.size),this.currentSize>=this.size}roll(e){const t=this,n=new RegExp(`^${na.basename(e)}`);function r(e){return n.test(e)}function u(t){return parseInt(t.substring(`${na.basename(e)}.`.length),10)||0}function o(e,t){return u(e)>u(t)?1:u(e) ${e}.${r+1}`),ra.renameSync(na.join(na.dirname(e),n),`${e}.${r+1}`)}}ta("Rolling, rolling, rolling"),ta("Renaming the old files"),ra.readdirSync(na.dirname(e)).filter(r).sort(o).reverse().forEach(i)}write(e,t){const n=this;ta("in write"),this.shouldRoll()&&(this.currentSize=0,this.roll(this.filename)),ta("writing the chunk to the file"),n.currentSize+=e.length,ra.appendFileSync(n.filename,e)}}ea.configure=function(e,t){let n=t.basicLayout;e.layout&&(n=t.layout(e.layout.type,e.layout));const r={flags:e.flags||"a",encoding:e.encoding||"utf8",mode:e.mode||384};return function(e,t,n,r,u,o){ta("fileSync appender created");const i=function(e,t,n){let r;var u;return t?r=new ia(e,t,n,o):(oa(u=e,o),r={write(e){ra.appendFileSync(u,e)}}),r}(e=na.normalize(e),n,r=r||0===r?r:5);return e=>{i.write(t(e,u)+ua)}}(e.filename,n,e.maxLogSize,e.backups,e.timezoneOffset,r)};var sa={};const ca=Nr.exports("log4js:tcp"),aa=S.default;sa.configure=function(e,t){ca(`configure with config = ${e}`);let n=function(e){return e.serialise()};return e.layout&&(n=t.layout(e.layout.type,e.layout)),function(e,t){let n=!1;const r=[];let u,o=3,i="__LOG4JS__";function s(e){ca("Writing log event to socket"),n=u.write(`${t(e)}${i}`,"utf8")}function c(){let e;for(ca("emptying buffer");e=r.shift();)s(e)}function a(e){n?s(e):(ca("buffering log event because it cannot write at the moment"),r.push(e))}return function t(){ca(`appender creating socket to ${e.host||"localhost"}:${e.port||5e3}`),i=`${e.endMsg||"__LOG4JS__"}`,u=aa.createConnection(e.port||5e3,e.host||"localhost"),u.on("connect",(()=>{ca("socket connected"),c(),n=!0})),u.on("drain",(()=>{ca("drain event received, emptying buffer"),n=!0,c()})),u.on("timeout",u.end.bind(u)),u.on("error",(e=>{ca("connection error",e),n=!1,c()})),u.on("close",t)}(),a.shutdown=function(e){ca("shutdown called"),r.length&&o?(ca("buffer has items, waiting 100ms to empty"),o-=1,setTimeout((()=>{a.shutdown(e)}),100)):(u.removeAllListeners("close"),u.end(e))},a}(e,n)};const la=p.default,fa=Nr.exports("log4js:appenders"),da=tu,Da=eo,pa=gu,Ea=hu,ma=to,ha=new Map;ha.set("console",oo),ha.set("stdout",so),ha.set("stderr",co),ha.set("logLevelFilter",ao),ha.set("categoryFilter",lo),ha.set("noLogFilter",Do),ha.set("file",Eo),ha.set("dateFile",Yc),ha.set("fileSync",ea),ha.set("tcp",sa);const ya=new Map,Ca=(e,t)=>{fa("Loading module from ",e);try{return require(e)}catch(n){return void da.throwExceptionIf(t,"MODULE_NOT_FOUND"!==n.code,`appender "${e}" could not be loaded (error was: ${n})`)}},Fa=new Set,ga=(e,t)=>{if(ya.has(e))return ya.get(e);if(!t.appenders[e])return!1;if(Fa.has(e))throw new Error(`Dependency loop detected for appender ${e}.`);Fa.add(e),fa(`Creating appender ${e}`);const n=Aa(e,t);return Fa.delete(e),ya.set(e,n),n},Aa=(e,t)=>{const n=t.appenders[e],r=n.type.configure?n.type:((e,t)=>ha.get(e)||Ca(`./${e}`,t)||Ca(e,t)||require.main&&Ca(la.join(la.dirname(require.main.filename),e),t)||Ca(la.join(process.cwd(),e),t))(n.type,t);return da.throwExceptionIf(t,da.not(r),`appender "${e}" is not valid (type "${n.type}" could not be found)`),r.appender&&fa(`DEPRECATION: Appender ${n.type} exports an appender function.`),r.shutdown&&fa(`DEPRECATION: Appender ${n.type} exports a shutdown function.`),fa(`${e}: clustering.isMaster ? ${Da.isMaster()}`),fa(`${e}: appenderModule is ${F.default.inspect(r)}`),Da.onlyOnMaster((()=>(fa(`calling appenderModule.configure for ${e} / ${n.type}`),r.configure(ma.modifyConfig(n),Ea,(e=>ga(e,t)),pa))),(()=>{}))},va=e=>{ya.clear(),Fa.clear();const t=[];Object.values(e.categories).forEach((e=>{t.push(...e.appenders)})),Object.keys(e.appenders).forEach((n=>{(t.includes(n)||"tcp-server"===e.appenders[n].type)&&ga(n,e)}))},Sa=()=>{va({appenders:{out:{type:"stdout"}},categories:{default:{appenders:["out"],level:"trace"}}})};Sa(),da.addListener((e=>{da.throwExceptionIf(e,da.not(da.anObject(e.appenders)),'must have a property "appenders" of type object.');const t=Object.keys(e.appenders);da.throwExceptionIf(e,da.not(t.length),"must define at least one appender."),t.forEach((t=>{da.throwExceptionIf(e,da.not(e.appenders[t].type),`appender "${t}" is not valid (must be an object with property "type")`)}))})),da.addListener(va),Au.exports=ya,Au.exports.init=Sa;var wa={exports:{}};!function(e){const t=Nr.exports("log4js:categories"),n=tu,r=gu,u=Au.exports,o=new Map;function i(e,t,n){if(!1===t.inherit)return;const r=n.lastIndexOf(".");if(r<0)return;const u=n.substring(0,r);let o=e.categories[u];o||(o={inherit:!0,appenders:[]}),i(e,o,u),!e.categories[u]&&o.appenders&&o.appenders.length&&o.level&&(e.categories[u]=o),t.appenders=t.appenders||[],t.level=t.level||o.level,o.appenders.forEach((e=>{t.appenders.includes(e)||t.appenders.push(e)})),t.parent=o}function s(e){if(!e.categories)return;Object.keys(e.categories).forEach((t=>{const n=e.categories[t];i(e,n,t)}))}n.addPreProcessingListener((e=>s(e))),n.addListener((e=>{n.throwExceptionIf(e,n.not(n.anObject(e.categories)),'must have a property "categories" of type object.');const t=Object.keys(e.categories);n.throwExceptionIf(e,n.not(t.length),"must define at least one category."),t.forEach((t=>{const o=e.categories[t];n.throwExceptionIf(e,[n.not(o.appenders),n.not(o.level)],`category "${t}" is not valid (must be an object with properties "appenders" and "level")`),n.throwExceptionIf(e,n.not(Array.isArray(o.appenders)),`category "${t}" is not valid (appenders must be an array of appender names)`),n.throwExceptionIf(e,n.not(o.appenders.length),`category "${t}" is not valid (appenders must contain at least one appender name)`),Object.prototype.hasOwnProperty.call(o,"enableCallStack")&&n.throwExceptionIf(e,"boolean"!=typeof o.enableCallStack,`category "${t}" is not valid (enableCallStack must be boolean type)`),o.appenders.forEach((r=>{n.throwExceptionIf(e,n.not(u.get(r)),`category "${t}" is not valid (appender "${r}" is not defined)`)})),n.throwExceptionIf(e,n.not(r.getLevel(o.level)),`category "${t}" is not valid (level "${o.level}" not recognised; valid levels are ${r.levels.join(", ")})`)})),n.throwExceptionIf(e,n.not(e.categories.default),'must define a "default" category.')}));const c=e=>{o.clear();Object.keys(e.categories).forEach((n=>{const i=e.categories[n],s=[];i.appenders.forEach((e=>{s.push(u.get(e)),t(`Creating category ${n}`),o.set(n,{appenders:s,level:r.getLevel(i.level),enableCallStack:i.enableCallStack||!1})}))}))},a=()=>{c({categories:{default:{appenders:["out"],level:"OFF"}}})};a(),n.addListener(c);const l=e=>(t(`configForCategory: searching for config for ${e}`),o.has(e)?(t(`configForCategory: ${e} exists in config, returning it`),o.get(e)):e.indexOf(".")>0?(t(`configForCategory: ${e} has hierarchy, searching for parents`),l(e.substring(0,e.lastIndexOf(".")))):(t("configForCategory: returning config for default category"),l("default")));e.exports=o,e.exports=Object.assign(e.exports,{appendersForCategory:e=>l(e).appenders,getLevelForCategory:e=>l(e).level,setLevelForCategory:(e,n)=>{let r=o.get(e);if(t(`setLevelForCategory: found ${r} for ${e}`),!r){const n=l(e);t(`setLevelForCategory: no config found for category, found ${n} for parents of ${e}`),r={appenders:n.appenders}}r.level=n,o.set(e,r)},getEnableCallStackForCategory:e=>!0===l(e).enableCallStack,setEnableCallStackForCategory:(e,t)=>{l(e).enableCallStack=t},init:a})}(wa);const Oa=Nr.exports("log4js:logger"),ba=Hu,_a=gu,Ba=eo,Pa=wa.exports,ka=tu,xa=/at (?:(.+)\s+\()?(?:(.+?):(\d+)(?::(\d+))?|([^)]+))\)?/;function Na(e,t=4){const n=e.stack.split("\n").slice(t),r=xa.exec(n[0]);return r&&6===r.length?{functionName:r[1],fileName:r[2],lineNumber:parseInt(r[3],10),columnNumber:parseInt(r[4],10),callStack:n.join("\n")}:null}class Ia{constructor(e){if(!e)throw new Error("No category provided.");this.category=e,this.context={},this.parseCallStack=Na,Oa(`Logger created (${this.category}, ${this.level})`)}get level(){return _a.getLevel(Pa.getLevelForCategory(this.category),_a.TRACE)}set level(e){Pa.setLevelForCategory(this.category,_a.getLevel(e,this.level))}get useCallStack(){return Pa.getEnableCallStackForCategory(this.category)}set useCallStack(e){Pa.setEnableCallStackForCategory(this.category,!0===e)}log(e,...t){let n=_a.getLevel(e);n||(this._log(_a.WARN,"log4js:logger.log: invalid value for log-level as first parameter given: ",e),n=_a.INFO),this.isLevelEnabled(n)&&this._log(n,t)}isLevelEnabled(e){return this.level.isLessThanOrEqualTo(e)}_log(e,t){Oa(`sending log data (${e}) to appenders`);const n=new ba(this.category,e,t,this.context,this.useCallStack&&this.parseCallStack(new Error));Ba.send(n)}addContext(e,t){this.context[e]=t}removeContext(e){delete this.context[e]}clearContext(){this.context={}}setParseCallStackFunction(e){this.parseCallStack=e}}function Ta(e){const t=_a.getLevel(e),n=t.toString().toLowerCase().replace(/_([a-z])/g,(e=>e[1].toUpperCase())),r=n[0].toUpperCase()+n.slice(1);Ia.prototype[`is${r}Enabled`]=function(){return this.isLevelEnabled(t)},Ia.prototype[n]=function(...e){this.log(t,...e)}}_a.levels.forEach(Ta),ka.addListener((()=>{_a.levels.forEach(Ta)}));var Ra=Ia;const Ma=gu;function La(e){return e.originalUrl||e.url}function ja(e,t){for(let n=0;ne.source?e.source:e));t=new RegExp(n.join("|"))}return t}(t.nolog);return(e,i,s)=>{if(e._logging)return s();if(o&&o.test(e.originalUrl))return s();if(n.isLevelEnabled(r)||"auto"===t.level){const o=new Date,{writeHead:s}=i;e._logging=!0,i.writeHead=(e,t)=>{i.writeHead=s,i.writeHead(e,t),i.__statusCode=e,i.__headers=t||{}},i.on("finish",(()=>{i.responseTime=new Date-o,i.statusCode&&"auto"===t.level&&(r=Ma.INFO,i.statusCode>=300&&(r=Ma.WARN),i.statusCode>=400&&(r=Ma.ERROR)),r=function(e,t,n){let r=t;if(n){const t=n.find((t=>{let n=!1;return n=t.from&&t.to?e>=t.from&&e<=t.to:-1!==t.codes.indexOf(e),n}));t&&(r=Ma.getLevel(t.level,r))}return r}(i.statusCode,r,t.statusRules);const s=function(e,t,n){const r=[];return r.push({token:":url",replacement:La(e)}),r.push({token:":protocol",replacement:e.protocol}),r.push({token:":hostname",replacement:e.hostname}),r.push({token:":method",replacement:e.method}),r.push({token:":status",replacement:t.__statusCode||t.statusCode}),r.push({token:":response-time",replacement:t.responseTime}),r.push({token:":date",replacement:(new Date).toUTCString()}),r.push({token:":referrer",replacement:e.headers.referer||e.headers.referrer||""}),r.push({token:":http-version",replacement:`${e.httpVersionMajor}.${e.httpVersionMinor}`}),r.push({token:":remote-addr",replacement:e.headers["x-forwarded-for"]||e.ip||e._remoteAddress||e.socket&&(e.socket.remoteAddress||e.socket.socket&&e.socket.socket.remoteAddress)}),r.push({token:":user-agent",replacement:e.headers["user-agent"]}),r.push({token:":content-length",replacement:t.getHeader("content-length")||t.__headers&&t.__headers["Content-Length"]||"-"}),r.push({token:/:req\[([^\]]+)]/g,replacement:(t,n)=>e.headers[n.toLowerCase()]}),r.push({token:/:res\[([^\]]+)]/g,replacement:(e,n)=>t.getHeader(n.toLowerCase())||t.__headers&&t.__headers[n]}),(e=>{const t=e.concat();for(let e=0;eja(e,s)));t&&n.log(r,t)}else n.log(r,ja(u,s));t.context&&n.removeContext("res")}))}return s()}},nl=Va;let rl=!1;function ul(e){if(!rl)return;Ua("Received log event ",e);Za.appendersForCategory(e.categoryName).forEach((t=>{t(e)}))}function ol(e){rl&&il();let t=e;return"string"==typeof t&&(t=function(e){Ua(`Loading configuration from ${e}`);try{return JSON.parse(Wa.readFileSync(e,"utf8"))}catch(t){throw new Error(`Problem reading config from file "${e}". Error was ${t.message}`,t)}}(e)),Ua(`Configuration is ${t}`),Ka.configure(za(t)),el.onMessage(ul),rl=!0,sl}function il(e){Ua("Shutdown called. Disabling all log writing."),rl=!1;const t=Array.from(Xa.values());Xa.init(),Za.init();const n=t.reduceRight(((e,t)=>t.shutdown?e+1:e),0);if(0===n)return Ua("No appenders with shutdown functions found."),void 0!==e&&e();let r,u=0;function o(t){r=r||t,u+=1,Ua(`Appender shutdowns complete: ${u} / ${n}`),u>=n&&(Ua("All shutdown functions completed."),e&&e(r))}return Ua(`Found ${n} appenders with shutdown functions.`),t.filter((e=>e.shutdown)).forEach((e=>e.shutdown(o))),null}const sl={getLogger:function(e){return rl||ol(process.env.LOG4JS_CONFIG||{appenders:{out:{type:"stdout"}},categories:{default:{appenders:["out"],level:"OFF"}}}),new Qa(e||"default")},configure:ol,shutdown:il,connectLogger:tl,levels:Ya,addLayout:qa.addLayout,recording:function(){return nl}};var cl=sl,al={};Object.defineProperty(al,"__esModule",{value:!0}),al.levelMap=al.getLevel=al.setCategoriesLevel=al.getConfiguration=al.setConfiguration=void 0;const ll=cl;let fl={appenders:{debug:{type:"stdout",layout:{type:"pattern",pattern:"[%d] > hvigor %p %c %[%m%]"}},info:{type:"stdout",layout:{type:"pattern",pattern:"[%d] > hvigor %[%m%]"}},"no-pattern-info":{type:"stdout",layout:{type:"pattern",pattern:"%m"}},wrong:{type:"stderr",layout:{type:"pattern",pattern:"[%d] > hvigor %[%p: %m%]"}},"just-debug":{type:"logLevelFilter",appender:"debug",level:"debug",maxLevel:"debug"},"just-info":{type:"logLevelFilter",appender:"info",level:"info",maxLevel:"info"},"just-wrong":{type:"logLevelFilter",appender:"wrong",level:"warn",maxLevel:"error"}},categories:{default:{appenders:["just-debug","just-info","just-wrong"],level:"debug"},"no-pattern-info":{appenders:["no-pattern-info"],level:"info"}}};al.setConfiguration=e=>{fl=e};al.getConfiguration=()=>fl;let dl=ll.levels.DEBUG;al.setCategoriesLevel=(e,t)=>{dl=e;const n=fl.categories;for(const r in n)(null==t?void 0:t.includes(r))||Object.prototype.hasOwnProperty.call(n,r)&&(n[r].level=e.levelStr)};al.getLevel=()=>dl,al.levelMap=new Map([["ALL",ll.levels.ALL],["MARK",ll.levels.MARK],["TRACE",ll.levels.TRACE],["DEBUG",ll.levels.DEBUG],["INFO",ll.levels.INFO],["WARN",ll.levels.WARN],["ERROR",ll.levels.ERROR],["FATAL",ll.levels.FATAL],["OFF",ll.levels.OFF]]);var Dl=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),pl=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),El=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)"default"!==n&&Object.prototype.hasOwnProperty.call(e,n)&&Dl(t,e,n);return pl(t,e),t};Object.defineProperty(xr,"__esModule",{value:!0}),xr.evaluateLogLevel=xr.HvigorLogger=void 0;const ml=El(cl),hl=cl,yl=El(F.default),Cl=al;class Fl{constructor(e){ml.configure((0,Cl.getConfiguration)()),this._logger=ml.getLogger(e),this._logger.level=(0,Cl.getLevel)()}static getLogger(e){return new Fl(e)}log(e,...t){this._logger.log(e,...t)}debug(e,...t){this._logger.debug(e,...t)}info(e,...t){this._logger.info(e,...t)}warn(e,...t){void 0!==e&&""!==e&&this._logger.warn(e,...t)}error(e,...t){this._logger.error(e,...t)}_printTaskExecuteInfo(e,t){this.info(`Finished :${e}... after ${t}`)}_printFailedTaskInfo(e){this.error(`Failed :${e}... `)}_printDisabledTaskInfo(e){this.info(`Disabled :${e}... `)}_printUpToDateTaskInfo(e){this.info(`UP-TO-DATE :${e}... `)}errorMessageExit(e,...t){throw new Error(yl.format(e,...t))}errorExit(e,t,...n){t&&this._logger.error(t,n),this._logger.error(e.stack)}setLevel(e,t){(0,Cl.setCategoriesLevel)(e,t),ml.shutdown(),ml.configure((0,Cl.getConfiguration)())}getLevel(){return this._logger.level}configure(e){const t=(0,Cl.getConfiguration)(),n={appenders:{...t.appenders,...e.appenders},categories:{...t.categories,...e.categories}};(0,Cl.setConfiguration)(n),ml.shutdown(),ml.configure(n)}}xr.HvigorLogger=Fl,xr.evaluateLogLevel=function(e,t){t.debug?e.setLevel(hl.levels.DEBUG):t.warn?e.setLevel(hl.levels.WARN):t.error?e.setLevel(hl.levels.ERROR):e.setLevel(hl.levels.INFO)};var gl=w&&w.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(X,"__esModule",{value:!0}),X.parseJsonText=X.parseJsonFile=void 0;const Al=Z,vl=gl(kr),Sl=gl(p.default),wl=gl(E.default),Ol=xr.HvigorLogger.getLogger("parse-json-util");var bl;!function(e){e[e.Char=0]="Char",e[e.EOF=1]="EOF",e[e.Identifier=2]="Identifier"}(bl||(bl={}));let _l,Bl,Pl,kl,xl,Nl,Il="start",Tl=[],Rl=0,Ml=1,Ll=0,jl=!1,$l="default",Hl="'",Jl=1;function Gl(e,t=!1){Bl=String(e),Il="start",Tl=[],Rl=0,Ml=1,Ll=0,kl=void 0,jl=t;do{_l=Vl(),Xl[Il]()}while("eof"!==_l.type);return kl}function Vl(){for($l="default",xl="",Hl="'",Jl=1;;){Nl=Ul();const e=zl[$l]();if(e)return e}}function Ul(){if(Bl[Rl])return String.fromCodePoint(Bl.codePointAt(Rl))}function Wl(){const e=Ul();return"\n"===e?(Ml++,Ll=0):e?Ll+=e.length:Ll++,e&&(Rl+=e.length),e}X.parseJsonFile=function(e,t=!1,n="utf-8"){const r=vl.default.readFileSync(Sl.default.resolve(e),{encoding:n});try{return Gl(r,t)}catch(t){if(t instanceof SyntaxError){const n=t.message.split("at");2===n.length&&Ol.errorMessageExit(`${n[0].trim()}${wl.default.EOL}\t at ${e}:${n[1].trim()}`)}Ol.errorMessageExit(`${e} is not in valid JSON/JSON5 format.`)}},X.parseJsonText=Gl;const zl={default(){switch(Nl){case"/":return Wl(),void($l="comment");case void 0:return Wl(),Kl("eof")}if(!Al.JudgeUtil.isIgnoreChar(Nl)&&!Al.JudgeUtil.isSpaceSeparator(Nl))return zl[Il]();Wl()},start(){$l="value"},beforePropertyName(){switch(Nl){case"$":case"_":return xl=Wl(),void($l="identifierName");case"\\":return Wl(),void($l="identifierNameStartEscape");case"}":return Kl("punctuator",Wl());case'"':case"'":return Hl=Nl,Wl(),void($l="string")}if(Al.JudgeUtil.isIdStartChar(Nl))return xl+=Wl(),void($l="identifierName");throw tf(bl.Char,Wl())},afterPropertyName(){if(":"===Nl)return Kl("punctuator",Wl());throw tf(bl.Char,Wl())},beforePropertyValue(){$l="value"},afterPropertyValue(){switch(Nl){case",":case"}":return Kl("punctuator",Wl())}throw tf(bl.Char,Wl())},beforeArrayValue(){if("]"===Nl)return Kl("punctuator",Wl());$l="value"},afterArrayValue(){switch(Nl){case",":case"]":return Kl("punctuator",Wl())}throw tf(bl.Char,Wl())},end(){throw tf(bl.Char,Wl())},comment(){switch(Nl){case"*":return Wl(),void($l="multiLineComment");case"/":return Wl(),void($l="singleLineComment")}throw tf(bl.Char,Wl())},multiLineComment(){switch(Nl){case"*":return Wl(),void($l="multiLineCommentAsterisk");case void 0:throw tf(bl.Char,Wl())}Wl()},multiLineCommentAsterisk(){switch(Nl){case"*":return void Wl();case"/":return Wl(),void($l="default");case void 0:throw tf(bl.Char,Wl())}Wl(),$l="multiLineComment"},singleLineComment(){switch(Nl){case"\n":case"\r":case"\u2028":case"\u2029":return Wl(),void($l="default");case void 0:return Wl(),Kl("eof")}Wl()},value(){switch(Nl){case"{":case"[":return Kl("punctuator",Wl());case"n":return Wl(),ql("ull"),Kl("null",null);case"t":return Wl(),ql("rue"),Kl("boolean",!0);case"f":return Wl(),ql("alse"),Kl("boolean",!1);case"-":case"+":return"-"===Wl()&&(Jl=-1),void($l="numerical");case".":case"0":case"I":case"N":return void($l="numerical");case'"':case"'":return Hl=Nl,Wl(),xl="",void($l="string")}if(void 0===Nl||!Al.JudgeUtil.isDigitWithoutZero(Nl))throw tf(bl.Char,Wl());$l="numerical"},numerical(){switch(Nl){case".":return xl=Wl(),void($l="decimalPointLeading");case"0":return xl=Wl(),void($l="zero");case"I":return Wl(),ql("nfinity"),Kl("numeric",Jl*(1/0));case"N":return Wl(),ql("aN"),Kl("numeric",NaN)}if(void 0!==Nl&&Al.JudgeUtil.isDigitWithoutZero(Nl))return xl=Wl(),void($l="decimalInteger");throw tf(bl.Char,Wl())},zero(){switch(Nl){case".":case"e":case"E":return void($l="decimal");case"x":case"X":return xl+=Wl(),void($l="hexadecimal")}return Kl("numeric",0)},decimalInteger(){switch(Nl){case".":case"e":case"E":return void($l="decimal")}if(!Al.JudgeUtil.isDigit(Nl))return Kl("numeric",Jl*Number(xl));xl+=Wl()},decimal(){switch(Nl){case".":xl+=Wl(),$l="decimalFraction";break;case"e":case"E":xl+=Wl(),$l="decimalExponent"}},decimalPointLeading(){if(Al.JudgeUtil.isDigit(Nl))return xl+=Wl(),void($l="decimalFraction");throw tf(bl.Char,Wl())},decimalFraction(){switch(Nl){case"e":case"E":return xl+=Wl(),void($l="decimalExponent")}if(!Al.JudgeUtil.isDigit(Nl))return Kl("numeric",Jl*Number(xl));xl+=Wl()},decimalExponent(){switch(Nl){case"+":case"-":return xl+=Wl(),void($l="decimalExponentSign")}if(Al.JudgeUtil.isDigit(Nl))return xl+=Wl(),void($l="decimalExponentInteger");throw tf(bl.Char,Wl())},decimalExponentSign(){if(Al.JudgeUtil.isDigit(Nl))return xl+=Wl(),void($l="decimalExponentInteger");throw tf(bl.Char,Wl())},decimalExponentInteger(){if(!Al.JudgeUtil.isDigit(Nl))return Kl("numeric",Jl*Number(xl));xl+=Wl()},hexadecimal(){if(Al.JudgeUtil.isHexDigit(Nl))return xl+=Wl(),void($l="hexadecimalInteger");throw tf(bl.Char,Wl())},hexadecimalInteger(){if(!Al.JudgeUtil.isHexDigit(Nl))return Kl("numeric",Jl*Number(xl));xl+=Wl()},identifierNameStartEscape(){if("u"!==Nl)throw tf(bl.Char,Wl());Wl();const e=Yl();switch(e){case"$":case"_":break;default:if(!Al.JudgeUtil.isIdStartChar(e))throw tf(bl.Identifier)}xl+=e,$l="identifierName"},identifierName(){switch(Nl){case"$":case"_":case"":case"":return void(xl+=Wl());case"\\":return Wl(),void($l="identifierNameEscape")}if(!Al.JudgeUtil.isIdContinueChar(Nl))return Kl("identifier",xl);xl+=Wl()},identifierNameEscape(){if("u"!==Nl)throw tf(bl.Char,Wl());Wl();const e=Yl();switch(e){case"$":case"_":case"":case"":break;default:if(!Al.JudgeUtil.isIdContinueChar(e))throw tf(bl.Identifier)}xl+=e,$l="identifierName"},string(){switch(Nl){case"\\":return Wl(),void(xl+=function(){const e=Ul(),t=function(){switch(Ul()){case"b":return Wl(),"\b";case"f":return Wl(),"\f";case"n":return Wl(),"\n";case"r":return Wl(),"\r";case"t":return Wl(),"\t";case"v":return Wl(),"\v"}return}();if(t)return t;switch(e){case"0":if(Wl(),Al.JudgeUtil.isDigit(Ul()))throw tf(bl.Char,Wl());return"\0";case"x":return Wl(),function(){let e="",t=Ul();if(!Al.JudgeUtil.isHexDigit(t))throw tf(bl.Char,Wl());if(e+=Wl(),t=Ul(),!Al.JudgeUtil.isHexDigit(t))throw tf(bl.Char,Wl());return e+=Wl(),String.fromCodePoint(parseInt(e,16))}();case"u":return Wl(),Yl();case"\n":case"\u2028":case"\u2029":return Wl(),"";case"\r":return Wl(),"\n"===Ul()&&Wl(),""}if(void 0===e||Al.JudgeUtil.isDigitWithoutZero(e))throw tf(bl.Char,Wl());return Wl()}());case'"':case"'":if(Nl===Hl){const e=Kl("string",xl);return Wl(),e}return void(xl+=Wl());case"\n":case"\r":case void 0:throw tf(bl.Char,Wl());case"\u2028":case"\u2029":!function(e){Ol.warn(`JSON5: '${ef(e)}' in strings is not valid ECMAScript; consider escaping.`)}(Nl)}xl+=Wl()}};function Kl(e,t){return{type:e,value:t,line:Ml,column:Ll}}function ql(e){for(const t of e){if(Ul()!==t)throw tf(bl.Char,Wl());Wl()}}function Yl(){let e="",t=4;for(;t-- >0;){const t=Ul();if(!Al.JudgeUtil.isHexDigit(t))throw tf(bl.Char,Wl());e+=Wl()}return String.fromCodePoint(parseInt(e,16))}const Xl={start(){if("eof"===_l.type)throw tf(bl.EOF);Zl()},beforePropertyName(){switch(_l.type){case"identifier":case"string":return Pl=_l.value,void(Il="afterPropertyName");case"punctuator":return void Ql();case"eof":throw tf(bl.EOF)}},afterPropertyName(){if("eof"===_l.type)throw tf(bl.EOF);Il="beforePropertyValue"},beforePropertyValue(){if("eof"===_l.type)throw tf(bl.EOF);Zl()},afterPropertyValue(){if("eof"===_l.type)throw tf(bl.EOF);switch(_l.value){case",":return void(Il="beforePropertyName");case"}":Ql()}},beforeArrayValue(){if("eof"===_l.type)throw tf(bl.EOF);"punctuator"!==_l.type||"]"!==_l.value?Zl():Ql()},afterArrayValue(){if("eof"===_l.type)throw tf(bl.EOF);switch(_l.value){case",":return void(Il="beforeArrayValue");case"]":Ql()}},end(){}};function Zl(){const e=function(){let e;switch(_l.type){case"punctuator":switch(_l.value){case"{":e={};break;case"[":e=[]}break;case"null":case"boolean":case"numeric":case"string":e=_l.value}return e}();if(jl&&"object"==typeof e&&(e._line=Ml,e._column=Ll),void 0===kl)kl=e;else{const t=Tl[Tl.length-1];Array.isArray(t)?jl&&"object"!=typeof e?t.push({value:e,_line:Ml,_column:Ll}):t.push(e):t[Pl]=jl&&"object"!=typeof e?{value:e,_line:Ml,_column:Ll}:e}!function(e){if(e&&"object"==typeof e)Tl.push(e),Il=Array.isArray(e)?"beforeArrayValue":"beforePropertyName";else{const e=Tl[Tl.length-1];Il=e?Array.isArray(e)?"afterArrayValue":"afterPropertyValue":"end"}}(e)}function Ql(){Tl.pop();const e=Tl[Tl.length-1];Il=e?Array.isArray(e)?"afterArrayValue":"afterPropertyValue":"end"}function ef(e){const t={"'":"\\'",'"':'\\"',"\\":"\\\\","\b":"\\b","\f":"\\f","\n":"\\n","\r":"\\r","\t":"\\t","\v":"\\v","\0":"\\0","\u2028":"\\u2028","\u2029":"\\u2029"};if(t[e])return t[e];if(e<" "){const t=e.charCodeAt(0).toString(16);return`\\x${`00${t}`.substring(t.length)}`}return e}function tf(e,t){let n="";switch(e){case bl.Char:n=void 0===t?`JSON5: invalid end of input at ${Ml}:${Ll}`:`JSON5: invalid character '${ef(t)}' at ${Ml}:${Ll}`;break;case bl.EOF:n=`JSON5: invalid end of input at ${Ml}:${Ll}`;break;case bl.Identifier:Ll-=5,n=`JSON5: invalid identifier character at ${Ml}:${Ll}`}const r=new nf(n);return r.lineNumber=Ml,r.columnNumber=Ll,r}class nf extends SyntaxError{}var rf=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),uf=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),of=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)"default"!==n&&Object.prototype.hasOwnProperty.call(e,n)&&rf(t,e,n);return uf(t,e),t};Object.defineProperty(Y,"__esModule",{value:!0});var sf=Y.cleanWorkSpace=Ff=Y.executeInstallHvigor=yf=Y.isHvigorInstalled=mf=Y.isAllDependenciesInstalled=void 0;const cf=of(D.default),af=of(p.default),lf=b,ff=j,df=$,Df=X;let pf,Ef;var mf=Y.isAllDependenciesInstalled=function(){function e(e){const t=null==e?void 0:e.dependencies;return void 0===t?0:Object.getOwnPropertyNames(t).length}if(pf=gf(),Ef=Af(),e(pf)+1!==e(Ef))return!1;for(const e in null==pf?void 0:pf.dependencies)if(!(0,ff.hasNpmPackInPaths)(e,[lf.HVIGOR_PROJECT_DEPENDENCIES_HOME])||!hf(e,pf,Ef))return!1;return!0};function hf(e,t,n){return void 0!==n.dependencies&&(0,ff.offlinePluginConversion)(lf.HVIGOR_PROJECT_ROOT_DIR,t.dependencies[e])===n.dependencies[e]}var yf=Y.isHvigorInstalled=function(){return pf=gf(),Ef=Af(),(0,ff.hasNpmPackInPaths)(lf.HVIGOR_ENGINE_PACKAGE_NAME,[lf.HVIGOR_PROJECT_DEPENDENCIES_HOME])&&(0,ff.offlinePluginConversion)(lf.HVIGOR_PROJECT_ROOT_DIR,pf.hvigorVersion)===Ef.dependencies[lf.HVIGOR_ENGINE_PACKAGE_NAME]};const Cf={cwd:lf.HVIGOR_PROJECT_DEPENDENCIES_HOME,stdio:["inherit","inherit","inherit"]};var Ff=Y.executeInstallHvigor=function(){(0,df.logInfoPrintConsole)("Hvigor installing...");const e={dependencies:{}};e.dependencies[lf.HVIGOR_ENGINE_PACKAGE_NAME]=(0,ff.offlinePluginConversion)(lf.HVIGOR_PROJECT_ROOT_DIR,pf.hvigorVersion);try{cf.mkdirSync(lf.HVIGOR_PROJECT_DEPENDENCIES_HOME,{recursive:!0});const t=af.resolve(lf.HVIGOR_PROJECT_DEPENDENCIES_HOME,lf.DEFAULT_PACKAGE_JSON);cf.writeFileSync(t,JSON.stringify(e))}catch(e){(0,df.logErrorAndExit)(e)}!function(){const e=["config","set","store-dir",lf.HVIGOR_PNPM_STORE_PATH];(0,ff.executeCommand)(lf.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH,e,Cf)}(),(0,ff.executeCommand)(lf.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH,["install"],Cf)};function gf(){const e=af.resolve(lf.HVIGOR_PROJECT_WRAPPER_HOME,lf.DEFAULT_HVIGOR_CONFIG_JSON_FILE_NAME);return cf.existsSync(e)||(0,df.logErrorAndExit)(`Error: Hvigor config file ${e} does not exist.`),(0,Df.parseJsonFile)(e)}function Af(){return cf.existsSync(lf.HVIGOR_PROJECT_DEPENDENCY_PACKAGE_JSON_PATH)?(0,Df.parseJsonFile)(lf.HVIGOR_PROJECT_DEPENDENCY_PACKAGE_JSON_PATH):{dependencies:{}}}sf=Y.cleanWorkSpace=function(){if((0,df.logInfoPrintConsole)("Hvigor cleaning..."),!cf.existsSync(lf.HVIGOR_PROJECT_DEPENDENCIES_HOME))return;const e=cf.readdirSync(lf.HVIGOR_PROJECT_DEPENDENCIES_HOME);if(e&&0!==e.length){cf.existsSync(lf.HVIGOR_BOOT_JS_FILE_PATH)&&(0,ff.executeCommand)(process.argv[0],[lf.HVIGOR_BOOT_JS_FILE_PATH,"--stop-daemon"],{});try{e.forEach((e=>{cf.rmSync(af.resolve(lf.HVIGOR_PROJECT_DEPENDENCIES_HOME,e),{recursive:!0})}))}catch(e){(0,df.logErrorAndExit)(`The hvigor build tool cannot be installed. Please manually clear the workspace directory and synchronize the project again.\n\n Workspace Path: ${lf.HVIGOR_PROJECT_DEPENDENCIES_HOME}.`)}}};var vf={},Sf=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),wf=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),Of=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)"default"!==n&&Object.prototype.hasOwnProperty.call(e,n)&&Sf(t,e,n);return wf(t,e),t};Object.defineProperty(vf,"__esModule",{value:!0});var bf=vf.executeBuild=void 0;const _f=b,Bf=Of(D.default),Pf=Of(p.default),kf=$;bf=vf.executeBuild=function(){const e=Pf.resolve(_f.HVIGOR_PROJECT_DEPENDENCIES_HOME,"node_modules","@ohos","hvigor","bin","hvigor.js");try{const t=Bf.realpathSync(e);require(t)}catch(t){(0,kf.logErrorAndExit)(`Error: ENOENT: no such file ${e},delete ${_f.HVIGOR_PROJECT_DEPENDENCIES_HOME} and retry.`)}},function(){if(O.checkNpmConifg(),O.environmentHandler(),O.isPnpmAvailable()||O.executeInstallPnpm(),yf()&&mf())bf();else{sf();try{Ff()}catch(e){return void sf()}bf()}}();
\ No newline at end of file
diff --git a/storage/storagesecuritylabeljstest/hvigorfile.ts b/storage/storagesecuritylabeljstest/hvigorfile.ts
deleted file mode 100644
index 0b9c10fc3ade5a54609b2d639f808ca7c25a611a..0000000000000000000000000000000000000000
--- a/storage/storagesecuritylabeljstest/hvigorfile.ts
+++ /dev/null
@@ -1,16 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-// Script for compiling build behavior. It is built in the build plug-in and cannot be modified currently.
-export { legacyAppTasks } from '@ohos/hvigor-ohos-plugin';
\ No newline at end of file
diff --git a/storage/storagesecuritylabeljstest/hvigorw b/storage/storagesecuritylabeljstest/hvigorw
deleted file mode 100755
index b4d7760e72934718fc616fcef2806a1c7f04ba34..0000000000000000000000000000000000000000
--- a/storage/storagesecuritylabeljstest/hvigorw
+++ /dev/null
@@ -1,61 +0,0 @@
-# Copyright (c) 2023 Huawei Device Co., Ltd.
-# Licensed under the Apache License, Version 2.0 (the "License");
-# you may not use this file except in compliance with the License.
-# You may obtain a copy of the License at
-#
-# http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-
-#!/bin/bash
-
-# ----------------------------------------------------------------------------
-# Hvigor startup script, version 1.0.0
-#
-# Required ENV vars:
-# ------------------
-# NODE_HOME - location of a Node home dir
-# or
-# Add /usr/local/nodejs/bin to the PATH environment variable
-# ----------------------------------------------------------------------------
-
-HVIGOR_APP_HOME=$(dirname $(readlink -f $0))
-HVIGOR_WRAPPER_SCRIPT=${HVIGOR_APP_HOME}/hvigor/hvigor-wrapper.js
-warn() {
- echo ""
- echo -e "\033[1;33m`date '+[%Y-%m-%d %H:%M:%S]'`$@\033[0m"
-}
-
-error() {
- echo ""
- echo -e "\033[1;31m`date '+[%Y-%m-%d %H:%M:%S]'`$@\033[0m"
-}
-
-fail() {
- error "$@"
- exit 1
-}
-
-# Determine node to start hvigor wrapper script
-if [ -n "${NODE_HOME}" ];then
- EXECUTABLE_NODE="${NODE_HOME}/bin/node"
- if [ ! -x "$EXECUTABLE_NODE" ];then
- fail "ERROR: NODE_HOME is set to an invalid directory,check $NODE_HOME\n\nPlease set NODE_HOME in your environment to the location where your nodejs installed"
- fi
-else
- EXECUTABLE_NODE="node"
- which ${EXECUTABLE_NODE} > /dev/null 2>&1 || fail "ERROR: NODE_HOME is not set and not 'node' command found in your path"
-fi
-
-# Check hvigor wrapper script
-if [ ! -r "$HVIGOR_WRAPPER_SCRIPT" ];then
- fail "ERROR: Couldn't find hvigor/hvigor-wrapper.js in ${HVIGOR_APP_HOME}"
-fi
-
-# start hvigor-wrapper script
-exec "${EXECUTABLE_NODE}" \
- "${HVIGOR_WRAPPER_SCRIPT}" "$@"
diff --git a/storage/storagesecuritylabeljstest/hvigorw.bat b/storage/storagesecuritylabeljstest/hvigorw.bat
deleted file mode 100644
index a9cc1302dc821de7f9f82c3327673a730945ec7d..0000000000000000000000000000000000000000
--- a/storage/storagesecuritylabeljstest/hvigorw.bat
+++ /dev/null
@@ -1,70 +0,0 @@
-@rem Copyright (C) 2023 Huawei Device Co., Ltd.
-@rem Licensed under the Apache License, Version 2.0 (the "License");
-@rem you may not use this file except in compliance with the License.
-@rem You may obtain a copy of the License at
-@rem
-@rem http://www.apache.org/licenses/LICENSE-2.0
-@rem
-@rem Unless required by applicable law or agreed to in writing, software
-@rem distributed under the License is distributed on an "AS IS" BASIS,
-@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-@rem See the License for the specific language governing permissions and
-@rem limitations under the License.
-
-@if "%DEBUG%" == "" @echo off
-@rem ##########################################################################
-@rem
-@rem Hvigor startup script for Windows
-@rem
-@rem ##########################################################################
-
-@rem Set local scope for the variables with windows NT shell
-if "%OS%"=="Windows_NT" setlocal
-
-set DIRNAME=%~dp0
-if "%DIRNAME%" == "" set DIRNAME=.
-set APP_BASE_NAME=%~n0
-set APP_HOME=%DIRNAME%
-
-@rem Resolve any "." and ".." in APP_HOME to make it shorter.
-for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi
-
-set WRAPPER_MODULE_PATH=%APP_HOME%\hvigor\hvigor-wrapper.js
-set NODE_EXE=node.exe
-
-goto start
-
-:start
-@rem Find node.exe
-if defined NODE_HOME goto findNodeFromNodeHome
-
-%NODE_EXE% --version >NUL 2>&1
-if "%ERRORLEVEL%" == "0" goto execute
-
-echo.
-echo ERROR: NODE_HOME is not set and no 'node' command could be found in your PATH.
-echo.
-echo Please set the NODE_HOME variable in your environment to match the
-echo location of your NodeJs installation.
-
-goto fail
-
-:findNodeFromNodeHome
-set NODE_HOME=%NODE_HOME:"=%
-set NODE_EXE_PATH=%NODE_HOME%/%NODE_EXE%
-
-if exist "%NODE_EXE_PATH%" goto execute
-echo.
-echo ERROR: NODE_HOME is not set and no 'node' command could be found in your PATH.
-echo.
-echo Please set the NODE_HOME variable in your environment to match the
-echo location of your NodeJs installation.
-
-goto fail
-
-:execute
-@rem Execute hvigor
-"%NODE_EXE%" %WRAPPER_MODULE_PATH% %*
-
-:fail
-exit /b 1
diff --git a/storage/storagesecuritylabeljstest/oh-package.json5 b/storage/storagesecuritylabeljstest/oh-package.json5
deleted file mode 100644
index 1a98aac1810691829d1f9908395de4863cb0623d..0000000000000000000000000000000000000000
--- a/storage/storagesecuritylabeljstest/oh-package.json5
+++ /dev/null
@@ -1,26 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-{
- "license": "",
- "devDependencies": {
- "@ohos/hypium": "1.0.6"
- },
- "author": "",
- "name": "myapplication454434",
- "description": "Please describe the basic information.",
- "main": "",
- "version": "1.0.0",
- "dependencies": {}
-}
diff --git a/storage/storagesecuritylabeljstest/src/main/config.json b/storage/storagesecuritylabeljstest/src/main/config.json
new file mode 100644
index 0000000000000000000000000000000000000000..f193f25023a4f8147fd7ce85a67ec736675d41c6
--- /dev/null
+++ b/storage/storagesecuritylabeljstest/src/main/config.json
@@ -0,0 +1,96 @@
+{
+ "app": {
+ "bundleName": "ohos.acts.storage.securitylabel",
+ "vendor": "example",
+ "version": {
+ "code": 1000000,
+ "name": "1.0.0"
+ },
+ "apiVersion": {
+ "compatible": 4,
+ "target": 5
+ }
+ },
+ "deviceConfig": {},
+ "module": {
+ "package": "ohos.acts.storage.securitylabel",
+ "name": ".entry",
+ "deviceType": [
+ "tablet",
+ "default",
+ "phone"
+ ],
+ "distro": {
+ "deliveryWithInstall": true,
+ "moduleName": "entry",
+ "moduleType": "entry",
+ "installationFree": true
+ },
+ "abilities": [
+ {
+ "skills": [
+ {
+ "entities": [
+ "entity.system.home"
+ ],
+ "actions": [
+ "action.system.home"
+ ]
+ }
+ ],
+ "orientation": "unspecified",
+ "formsEnabled": false,
+ "name": ".MainAbility",
+ "srcLanguage": "js",
+ "srcPath": "MainAbility",
+ "icon": "$media:icon",
+ "description": "$string:MainAbility_desc",
+ "label": "$string:MainAbility_label",
+ "type": "page",
+ "visible": true,
+ "launchType": "standard"
+ },
+ {
+ "orientation": "unspecified",
+ "formsEnabled": false,
+ "name": ".TestAbility",
+ "srcLanguage": "js",
+ "srcPath": "TestAbility",
+ "icon": "$media:icon",
+ "description": "$string:TestAbility_desc",
+ "label": "$string:TestAbility_label",
+ "type": "page",
+ "visible": true,
+ "launchType": "standard"
+ }
+ ],
+ "js": [
+ {
+ "pages": [
+ "pages/index/index"
+ ],
+ "name": "default",
+ "window": {
+ "designWidth": 720,
+ "autoDesignWidth": false
+ }
+ },
+ {
+ "pages": [
+ "pages/index/index"
+ ],
+ "name": ".TestAbility",
+ "window": {
+ "designWidth": 720,
+ "autoDesignWidth": false
+ }
+ }
+ ],
+ "testRunner": {
+ "name": "OpenHarmonyTestRunner",
+ "srcPath": "TestRunner"
+ },
+ "mainAbility": ".MainAbility",
+ "srcPath": ""
+ }
+}
\ No newline at end of file
diff --git a/storage/storagesecuritylabeljstest/src/main/js/MainAbility/app.js b/storage/storagesecuritylabeljstest/src/main/js/MainAbility/app.js
new file mode 100644
index 0000000000000000000000000000000000000000..60ee141c8dbd251c763b7b74552b5a133a774d6a
--- /dev/null
+++ b/storage/storagesecuritylabeljstest/src/main/js/MainAbility/app.js
@@ -0,0 +1,23 @@
+/*
+ * Copyright (C) 2021 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+export default {
+ onCreate() {
+ console.info('ohos.acts.distributeddatamgr.distributedfile onCreate');
+ },
+ onDestroy() {
+ console.info('ohos.acts.distributeddatamgr.distributedfile onCreate');
+ }
+};
diff --git a/storage/storagefilejstest/entry/src/main/js/MainAbility/i18n/en-US.json b/storage/storagesecuritylabeljstest/src/main/js/MainAbility/i18n/en-US.json
similarity index 61%
rename from storage/storagefilejstest/entry/src/main/js/MainAbility/i18n/en-US.json
rename to storage/storagesecuritylabeljstest/src/main/js/MainAbility/i18n/en-US.json
index a4c13dcbdc39c537073f638393d7726ac9a5cdc4..ead52ed2e09ec82aaf7aa9f4e714ed39ea88308e 100644
--- a/storage/storagefilejstest/entry/src/main/js/MainAbility/i18n/en-US.json
+++ b/storage/storagesecuritylabeljstest/src/main/js/MainAbility/i18n/en-US.json
@@ -1,6 +1,6 @@
-{
- "strings": {
- "hello": "Hello",
- "world": "World"
- }
+{
+ "strings": {
+ "hello": "Hello",
+ "world": "Test"
+ }
}
\ No newline at end of file
diff --git a/storage/storagesecuritylabeljstest/entry/src/main/js/MainAbility/i18n/zh-CN.json b/storage/storagesecuritylabeljstest/src/main/js/MainAbility/i18n/zh-CN.json
similarity index 61%
rename from storage/storagesecuritylabeljstest/entry/src/main/js/MainAbility/i18n/zh-CN.json
rename to storage/storagesecuritylabeljstest/src/main/js/MainAbility/i18n/zh-CN.json
index b1c02368f72f929e4375a43170444de95dcc5984..3f48f2585b24a8fe4a745e8ee2972a9e991a7803 100644
--- a/storage/storagesecuritylabeljstest/entry/src/main/js/MainAbility/i18n/zh-CN.json
+++ b/storage/storagesecuritylabeljstest/src/main/js/MainAbility/i18n/zh-CN.json
@@ -1,6 +1,6 @@
-{
- "strings": {
- "hello": "您好",
- "world": "世界"
- }
+{
+ "strings": {
+ "hello": "您好",
+ "world": "测试"
+ }
}
\ No newline at end of file
diff --git a/storage/storagesecuritylabeljstest/src/main/js/MainAbility/pages/index/index.css b/storage/storagesecuritylabeljstest/src/main/js/MainAbility/pages/index/index.css
new file mode 100644
index 0000000000000000000000000000000000000000..6fda792753f2e15f22b529c7b90a82185b2770bf
--- /dev/null
+++ b/storage/storagesecuritylabeljstest/src/main/js/MainAbility/pages/index/index.css
@@ -0,0 +1,9 @@
+.container {
+ flex-direction: column;
+ justify-content: center;
+ align-items: center;
+}
+
+.title {
+ font-size: 100px;
+}
diff --git a/storage/storagesecuritylabeljstest/src/main/js/MainAbility/pages/index/index.hml b/storage/storagesecuritylabeljstest/src/main/js/MainAbility/pages/index/index.hml
new file mode 100644
index 0000000000000000000000000000000000000000..f64b040a5ae394dbaa5e185e1ecd4f4556b92184
--- /dev/null
+++ b/storage/storagesecuritylabeljstest/src/main/js/MainAbility/pages/index/index.hml
@@ -0,0 +1,5 @@
+
+
+ {{ $t('strings.hello') }} {{ title }}
+
+
diff --git a/storage/storagesecuritylabeljstest/src/main/js/MainAbility/pages/index/index.js b/storage/storagesecuritylabeljstest/src/main/js/MainAbility/pages/index/index.js
new file mode 100644
index 0000000000000000000000000000000000000000..5f9fe94e4bc5dc38ed24399a7bc18167d42310fc
--- /dev/null
+++ b/storage/storagesecuritylabeljstest/src/main/js/MainAbility/pages/index/index.js
@@ -0,0 +1,34 @@
+/*
+ * Copyright (C) 2021 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import app from '@system.app'
+
+
+const injectRef = Object.getPrototypeOf(global) || global
+injectRef.regeneratorRuntime = require('@babel/runtime/regenerator')
+
+export default {
+ data: {
+ title: ''
+ },
+ onInit() {
+ this.title = this.$t('strings.world');
+ },
+ onShow() {
+ console.info('onShow finish')
+ },
+ onReady() {
+ },
+}
\ No newline at end of file
diff --git a/storage/storagefilejstest/entry/src/ohosTest/js/TestAbility/app.js b/storage/storagesecuritylabeljstest/src/main/js/TestAbility/app.js
similarity index 62%
rename from storage/storagefilejstest/entry/src/ohosTest/js/TestAbility/app.js
rename to storage/storagesecuritylabeljstest/src/main/js/TestAbility/app.js
index 469c4f1380182e0dccb04f17eb95d9b503a56d29..cdc31f3dcf031e2f6a7665d9653e53bb649e21c5 100644
--- a/storage/storagefilejstest/entry/src/ohosTest/js/TestAbility/app.js
+++ b/storage/storagesecuritylabeljstest/src/main/js/TestAbility/app.js
@@ -1,5 +1,5 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
+/*
+ * Copyright (c) 2022 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
@@ -12,22 +12,20 @@
* See the License for the specific language governing permissions and
* limitations under the License.
*/
-import hilog from '@ohos.hilog';
-import AbilityDelegatorRegistry from '@ohos.app.ability.abilityDelegatorRegistry';
-import { Hypium } from '@ohos/hypium';
-import testsuite from '../test/List.test';
+
+import AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry'
+import { Hypium } from '@ohos/hypium'
+import testsuite from '../test/List.test'
export default {
onCreate() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'TestApplication onCreate');
+ console.info('TestApplication onCreate')
var abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator()
var abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments()
- hilog.info(0x0000, 'testTag', '%{public}s', 'start run testcase!!!');
+ console.info('start run testcase!!!')
Hypium.hypiumTest(abilityDelegator, abilityDelegatorArguments, testsuite)
},
onDestroy() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'TestApplication onDestroy');
+ console.info("TestApplication onDestroy");
}
};
-
-
diff --git a/storage/storagesecuritylabeljstest/entry/src/ohosTest/js/TestAbility/i18n/en-US.json b/storage/storagesecuritylabeljstest/src/main/js/TestAbility/i18n/en-US.json
similarity index 91%
rename from storage/storagesecuritylabeljstest/entry/src/ohosTest/js/TestAbility/i18n/en-US.json
rename to storage/storagesecuritylabeljstest/src/main/js/TestAbility/i18n/en-US.json
index 55561b83737c3c31d082fbfa11e5fc987a351104..3cb24b374b1d919ca8eac0638f361692b603a900 100644
--- a/storage/storagesecuritylabeljstest/entry/src/ohosTest/js/TestAbility/i18n/en-US.json
+++ b/storage/storagesecuritylabeljstest/src/main/js/TestAbility/i18n/en-US.json
@@ -1,8 +1,8 @@
-{
- "strings": {
- "hello": "Hello",
- "world": "World"
- },
- "Files": {
- }
+{
+ "strings": {
+ "hello": "Hello",
+ "world": "World"
+ },
+ "Files": {
+ }
}
\ No newline at end of file
diff --git a/storage/storagesecuritylabeljstest/entry/src/ohosTest/js/TestAbility/i18n/zh-CN.json b/storage/storagesecuritylabeljstest/src/main/js/TestAbility/i18n/zh-CN.json
similarity index 91%
rename from storage/storagesecuritylabeljstest/entry/src/ohosTest/js/TestAbility/i18n/zh-CN.json
rename to storage/storagesecuritylabeljstest/src/main/js/TestAbility/i18n/zh-CN.json
index cce1af06761a42add0cac1a0567aa3237eda8cb4..c804e32c0c3103929baca5617cdac70be11fdba1 100644
--- a/storage/storagesecuritylabeljstest/entry/src/ohosTest/js/TestAbility/i18n/zh-CN.json
+++ b/storage/storagesecuritylabeljstest/src/main/js/TestAbility/i18n/zh-CN.json
@@ -1,8 +1,8 @@
-{
- "strings": {
- "hello": "您好",
- "world": "世界"
- },
- "Files": {
- }
+{
+ "strings": {
+ "hello": "您好",
+ "world": "世界"
+ },
+ "Files": {
+ }
}
\ No newline at end of file
diff --git a/storage/storagefilejstest/entry/src/ohosTest/js/TestAbility/pages/index/index.css b/storage/storagesecuritylabeljstest/src/main/js/TestAbility/pages/index/index.css
similarity index 100%
rename from storage/storagefilejstest/entry/src/ohosTest/js/TestAbility/pages/index/index.css
rename to storage/storagesecuritylabeljstest/src/main/js/TestAbility/pages/index/index.css
diff --git a/storage/storagesecuritylabeljstest/src/main/js/TestAbility/pages/index/index.hml b/storage/storagesecuritylabeljstest/src/main/js/TestAbility/pages/index/index.hml
new file mode 100644
index 0000000000000000000000000000000000000000..f629c71a9be857db6cdf94149652a191b9b272ea
--- /dev/null
+++ b/storage/storagesecuritylabeljstest/src/main/js/TestAbility/pages/index/index.hml
@@ -0,0 +1,5 @@
+
+
+ {{ $t('strings.hello') }} {{ title }}
+
+
diff --git a/storage/storagesecuritylabeljstest/entry/src/ohosTest/js/TestAbility/pages/index/index.js b/storage/storagesecuritylabeljstest/src/main/js/TestAbility/pages/index/index.js
similarity index 90%
rename from storage/storagesecuritylabeljstest/entry/src/ohosTest/js/TestAbility/pages/index/index.js
rename to storage/storagesecuritylabeljstest/src/main/js/TestAbility/pages/index/index.js
index ad113c0d214ce0d80c42c75c62d881547b6294ee..88b083a7f6b979019d6a2c5ad20b19c5fd43286b 100644
--- a/storage/storagesecuritylabeljstest/entry/src/ohosTest/js/TestAbility/pages/index/index.js
+++ b/storage/storagesecuritylabeljstest/src/main/js/TestAbility/pages/index/index.js
@@ -1,25 +1,26 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-export default {
- data: {
- title: ""
- },
- onInit() {
- this.title = this.$t('strings.world');
- }
-}
-
-
-
+/*
+ * Copyright (c) 2022 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+export default {
+ data: {
+ title: ""
+ },
+ onInit() {
+ this.title = this.$t('strings.world');
+ }
+}
+
+
+
diff --git a/storage/storagefilejstest/entry/src/ohosTest/js/TestRunner/OpenHarmonyTestRunner.js b/storage/storagesecuritylabeljstest/src/main/js/TestRunner/OpenHarmonyTestRunner.js
similarity index 51%
rename from storage/storagefilejstest/entry/src/ohosTest/js/TestRunner/OpenHarmonyTestRunner.js
rename to storage/storagesecuritylabeljstest/src/main/js/TestRunner/OpenHarmonyTestRunner.js
index 03ccc5b691574b1d5bc46adefc08d9ddfc4a1f5c..c5fa8620ca77d381f20b65a903b833e6e3378c97 100644
--- a/storage/storagefilejstest/entry/src/ohosTest/js/TestRunner/OpenHarmonyTestRunner.js
+++ b/storage/storagesecuritylabeljstest/src/main/js/TestRunner/OpenHarmonyTestRunner.js
@@ -1,41 +1,59 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-import hilog from '@ohos.hilog';
-import AbilityDelegatorRegistry from '@ohos.app.ability.abilityDelegatorRegistry';
-
- export default {
- onPrepare() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'OpenHarmonyTestRunner OnPrepare');
- },
- onRun() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'OpenHarmonyTestRunner onRun run');
- var abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments()
- var abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator()
-
- var testAbilityName = abilityDelegatorArguments.parameters['-p'] + '.TestAbility'
- var cmd = 'aa start -d 0 -a ' + testAbilityName + ' -b ' + abilityDelegatorArguments.bundleName
- var debug = abilityDelegatorArguments.parameters["-D"]
- if (debug == 'true')
- {
- cmd += ' -D'
- }
- hilog.info(0x0000, 'testTag', 'cmd : %{public}s', cmd);
- abilityDelegator.executeShellCommand(cmd, (err, data) => {
- hilog.info(0x0000, 'testTag', 'executeShellCommand : err : %{public}s', JSON.stringify(err) ?? '');
- hilog.info(0x0000, 'testTag', 'executeShellCommand : data : %{public}s', data.stdResult ?? '');
- hilog.info(0x0000, 'testTag', 'executeShellCommand : data : %{public}s', data.exitCode ?? '');
- })
- }
-};
\ No newline at end of file
+/*
+ * Copyright (c) 2022 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry'
+
+function translateParamsToString(parameters) {
+ const keySet = new Set([
+ '-s class', '-s notClass', '-s suite', '-s itName',
+ '-s level', '-s testType', '-s size', '-s timeout',
+ '-s package', '-s dryRun'
+ ])
+ let targetParams = '';
+ for (const key in parameters) {
+ if (keySet.has(key)) {
+ targetParams += ' ' + key + ' ' + parameters[key]
+ }
+ }
+ return targetParams.trim()
+}
+
+ export default {
+ onPrepare() {
+ console.info('OpenHarmonyTestRunner OnPrepare')
+ },
+ onRun() {
+ console.log('OpenHarmonyTestRunner onRun run')
+ var abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments()
+ var abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator()
+
+ var testAbilityName = abilityDelegatorArguments.parameters['-p'] + '.TestAbility'
+
+ var cmd = 'aa start -d 0 -a ' + testAbilityName + ' -b ' + abilityDelegatorArguments.bundleName
+ cmd += ' ' + translateParamsToString(abilityDelegatorArguments.parameters)
+ var debug = abilityDelegatorArguments.parameters["-D"]
+ console.info('debug value : '+debug)
+ if (debug == 'true')
+ {
+ cmd += ' -D'
+ }
+ console.info('cmd : '+cmd)
+ abilityDelegator.executeShellCommand(cmd, (err, data) => {
+ console.info('executeShellCommand : err : ' + JSON.stringify(err));
+ console.info('executeShellCommand : data : ' + data.stdResult);
+ console.info('executeShellCommand : data : ' + data.exitCode);
+ })
+ }
+};
diff --git a/storage/storagesecuritylabeljstest/entry/src/ohosTest/js/test/Common.js b/storage/storagesecuritylabeljstest/src/main/js/test/Common.js
similarity index 82%
rename from storage/storagesecuritylabeljstest/entry/src/ohosTest/js/test/Common.js
rename to storage/storagesecuritylabeljstest/src/main/js/test/Common.js
index d12fa7ccb69fd93f4d6788215c6709e5678f1857..769f0e4a2631176a9650cf709a48d95bff308658 100644
--- a/storage/storagesecuritylabeljstest/entry/src/ohosTest/js/test/Common.js
+++ b/storage/storagesecuritylabeljstest/src/main/js/test/Common.js
@@ -1,13 +1,13 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
+/*
+ * Copyright (C) 2021-2022 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
+ * distributed under the License is distributed on an 'AS IS' BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
diff --git a/storage/storagesecuritylabeljstest/entry/src/ohosTest/js/test/List.test.js b/storage/storagesecuritylabeljstest/src/main/js/test/List.test.js
similarity index 90%
rename from storage/storagesecuritylabeljstest/entry/src/ohosTest/js/test/List.test.js
rename to storage/storagesecuritylabeljstest/src/main/js/test/List.test.js
index d92adf06f97f687201a9a7edc7131d7c178ca9a6..074dfa6b698fbbfa691fe63c3cb9ecd2fb5e0547 100644
--- a/storage/storagesecuritylabeljstest/entry/src/ohosTest/js/test/List.test.js
+++ b/storage/storagesecuritylabeljstest/src/main/js/test/List.test.js
@@ -1,5 +1,5 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
+/*
+ * Copyright (C) 2021 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
diff --git a/storage/storagesecuritylabeljstest/entry/src/ohosTest/js/test/securitylabel.test.js b/storage/storagesecuritylabeljstest/src/main/js/test/securitylabel.test.js
similarity index 96%
rename from storage/storagesecuritylabeljstest/entry/src/ohosTest/js/test/securitylabel.test.js
rename to storage/storagesecuritylabeljstest/src/main/js/test/securitylabel.test.js
index 499c78c8329439252fe915ec8df20537ec8699fe..034e270e89aa3c5b860e9af4b01f0363b2271ab7 100644
--- a/storage/storagesecuritylabeljstest/entry/src/ohosTest/js/test/securitylabel.test.js
+++ b/storage/storagesecuritylabeljstest/src/main/js/test/securitylabel.test.js
@@ -1,13 +1,13 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
+/*
+ * Copyright (C) 2021-2022 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
+ * distributed under the License is distributed on an 'AS IS' BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
diff --git a/storage/storagesecuritylabeljstest/entry/src/main/resources/base/element/string.json b/storage/storagesecuritylabeljstest/src/main/resources/base/element/string.json
similarity index 100%
rename from storage/storagesecuritylabeljstest/entry/src/main/resources/base/element/string.json
rename to storage/storagesecuritylabeljstest/src/main/resources/base/element/string.json
diff --git a/storage/storagefilejstest/entry/src/ohosTest/resources/base/media/icon.png b/storage/storagesecuritylabeljstest/src/main/resources/base/media/icon.png
similarity index 100%
rename from storage/storagefilejstest/entry/src/ohosTest/resources/base/media/icon.png
rename to storage/storagesecuritylabeljstest/src/main/resources/base/media/icon.png
diff --git a/storage/storagestatfsjstest/BUILD.gn b/storage/storagestatfsjstest/BUILD.gn
index 344e2fe239060dea0c3adc6ab10034698159847e..755fc9208b185a080cf8ca0a39c6b07d61d00e4b 100644
--- a/storage/storagestatfsjstest/BUILD.gn
+++ b/storage/storagestatfsjstest/BUILD.gn
@@ -1,4 +1,4 @@
-# Copyright (c) 2023 Huawei Device Co., Ltd.
+# Copyright (C) 2021 Huawei Device Co., Ltd.
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
@@ -13,11 +13,23 @@
import("//test/xts/tools/build/suite.gni")
-ohos_js_app_suite("storagestatfs_js_test") {
- test_hap = true
- testonly = true
+ohos_js_hap_suite("storagestatfs_js_test") {
+ hap_profile = "./src/main/config.json"
+ deps = [
+ ":storagestatfs_js_assets",
+ ":storagestatfs_js_resources",
+ ]
+ certificate_profile = "./signature/openharmony_sx.p7b"
hap_name = "ActsStorageStatfsJsTest"
subsystem_name = "filemanagement"
part_name = "file_api"
- certificate_profile = "./signature/openharmony_sx.p7b"
+}
+ohos_js_assets("storagestatfs_js_assets") {
+ js2abc = true
+ hap_profile = "./src/main/config.json"
+ source_dir = "./src/main/js"
+}
+ohos_resources("storagestatfs_js_resources") {
+ sources = [ "./src/main/resources" ]
+ hap_profile = "./src/main/config.json"
}
diff --git a/storage/storagestatfsjstest/Test.json b/storage/storagestatfsjstest/Test.json
index 9e301cad03d6adac22111327b1015784f5eff566..30279b29af2cd2c069a8449d4f08fb579cdba597 100644
--- a/storage/storagestatfsjstest/Test.json
+++ b/storage/storagestatfsjstest/Test.json
@@ -5,7 +5,7 @@
"test-timeout": "60000",
"shell-timeout": "60000",
"bundle-name": "ohos.acts.storage.statfs",
- "package-name": "ohos.acts.storage.statfs_test"
+ "package-name": "ohos.acts.storage.statfs"
},
"kits": [
{
diff --git a/storage/storagestatfsjstest/build-profile.json5 b/storage/storagestatfsjstest/build-profile.json5
deleted file mode 100644
index 7715cddc0112e0e0c8e40623b77ff67b82731829..0000000000000000000000000000000000000000
--- a/storage/storagestatfsjstest/build-profile.json5
+++ /dev/null
@@ -1,42 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-{
- "app": {
- "signingConfigs": [
- ],
- "compileSdkVersion": 10,
- "compatibleSdkVersion": 10,
- "products": [
- {
- "name": "default",
- "signingConfig": "default"
- }
- ]
- },
- "modules": [
- {
- "name": "entry",
- "srcPath": "./entry",
- "targets": [
- {
- "name": "default",
- "applyToProducts": [
- "default"
- ]
- }
- ]
- }
- ]
-}
\ No newline at end of file
diff --git a/storage/storagestatfsjstest/entry/build-profile.json5 b/storage/storagestatfsjstest/entry/build-profile.json5
deleted file mode 100644
index a6a17e6971173aacea7b75d9ae897a80d335dc0b..0000000000000000000000000000000000000000
--- a/storage/storagestatfsjstest/entry/build-profile.json5
+++ /dev/null
@@ -1,27 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-{
- "apiType": 'faMode',
- "buildOption": {
- },
- "targets": [
- {
- "name": "default",
- },
- {
- "name": "ohosTest",
- }
- ]
-}
\ No newline at end of file
diff --git a/storage/storagestatfsjstest/entry/hvigorfile.ts b/storage/storagestatfsjstest/entry/hvigorfile.ts
deleted file mode 100644
index 89d831db3f5a6431ef4f9078128ad61b6ae36c48..0000000000000000000000000000000000000000
--- a/storage/storagestatfsjstest/entry/hvigorfile.ts
+++ /dev/null
@@ -1,16 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-// Script for compiling build behavior. It is built in the build plug-in and cannot be modified currently.
-export { legacyHapTasks } from '@ohos/hvigor-ohos-plugin';
diff --git a/storage/storagestatfsjstest/entry/oh-package.json5 b/storage/storagestatfsjstest/entry/oh-package.json5
deleted file mode 100644
index 75ca1d70feb1c490379299fe342058a2a7183388..0000000000000000000000000000000000000000
--- a/storage/storagestatfsjstest/entry/oh-package.json5
+++ /dev/null
@@ -1,24 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-{
- "license": "",
- "devDependencies": {},
- "author": "",
- "name": "entry",
- "description": "Please describe the basic information.",
- "main": "",
- "version": "1.0.0",
- "dependencies": {}
-}
diff --git a/storage/storagestatfsjstest/entry/src/main/config.json b/storage/storagestatfsjstest/entry/src/main/config.json
deleted file mode 100644
index bb77e6f7b72e9248dbca5030e134e12984b438d3..0000000000000000000000000000000000000000
--- a/storage/storagestatfsjstest/entry/src/main/config.json
+++ /dev/null
@@ -1,65 +0,0 @@
-{
- "app":{
- "bundleName":"ohos.acts.storage.statfs",
- "vendor":"example",
- "version":{
- "code":1000000,
- "name":"1.0.0"
- }
- },
- "deviceConfig":{
-
- },
- "module":{
- "package":"ohos.acts.storage.statfs",
- "name":".entry",
- "mainAbility":".MainAbility",
- "deviceType": [
- "tablet",
- "default"
- ],
- "distro":{
- "deliveryWithInstall":true,
- "installationFree":true,
- "moduleName":"entry",
- "moduleType":"entry"
- },
- "abilities":[
- {
- "description":"$string:MainAbility_desc",
- "formsEnabled":false,
- "icon":"$media:icon",
- "label":"$string:MainAbility_label",
- "launchType":"standard",
- "name":".MainAbility",
- "orientation":"unspecified",
- "skills":[
- {
- "actions":[
- "action.system.home"
- ],
- "entities":[
- "entity.system.home"
- ]
- }
- ],
- "srcLanguage":"js",
- "srcPath":"MainAbility",
- "type":"page",
- "visible":true
- }
- ],
- "js":[
- {
- "name":".MainAbility",
- "pages":[
- "pages/index/index"
- ],
- "window":{
- "autoDesignWidth":false,
- "designWidth":720
- }
- }
- ]
- }
-}
\ No newline at end of file
diff --git a/storage/storagestatfsjstest/entry/src/main/js/MainAbility/app.js b/storage/storagestatfsjstest/entry/src/main/js/MainAbility/app.js
deleted file mode 100644
index 8c9a4fce93b5e76779bdf446c49269a5a51db98a..0000000000000000000000000000000000000000
--- a/storage/storagestatfsjstest/entry/src/main/js/MainAbility/app.js
+++ /dev/null
@@ -1,26 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-import hilog from '@ohos.hilog';
-export default {
- onCreate() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'Application onCreate');
- },
- onDestroy() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'Application onDestroy');
- },
-}
-
-
-
diff --git a/storage/storagestatfsjstest/entry/src/main/js/MainAbility/i18n/en-US.json b/storage/storagestatfsjstest/entry/src/main/js/MainAbility/i18n/en-US.json
deleted file mode 100644
index a4c13dcbdc39c537073f638393d7726ac9a5cdc4..0000000000000000000000000000000000000000
--- a/storage/storagestatfsjstest/entry/src/main/js/MainAbility/i18n/en-US.json
+++ /dev/null
@@ -1,6 +0,0 @@
-{
- "strings": {
- "hello": "Hello",
- "world": "World"
- }
-}
\ No newline at end of file
diff --git a/storage/storagestatfsjstest/entry/src/main/js/MainAbility/i18n/zh-CN.json b/storage/storagestatfsjstest/entry/src/main/js/MainAbility/i18n/zh-CN.json
deleted file mode 100644
index b1c02368f72f929e4375a43170444de95dcc5984..0000000000000000000000000000000000000000
--- a/storage/storagestatfsjstest/entry/src/main/js/MainAbility/i18n/zh-CN.json
+++ /dev/null
@@ -1,6 +0,0 @@
-{
- "strings": {
- "hello": "您好",
- "world": "世界"
- }
-}
\ No newline at end of file
diff --git a/storage/storagestatfsjstest/entry/src/main/js/MainAbility/pages/index/index.css b/storage/storagestatfsjstest/entry/src/main/js/MainAbility/pages/index/index.css
deleted file mode 100644
index a711febae0b34889547cd72fbe5f8cc3e0bd043c..0000000000000000000000000000000000000000
--- a/storage/storagestatfsjstest/entry/src/main/js/MainAbility/pages/index/index.css
+++ /dev/null
@@ -1,60 +0,0 @@
-/*
- * Copyright (c) 2022 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-.container {
- flex-direction: column;
- justify-content: center;
- align-items: center;
- width: 100%;
- height: 100%;
-}
-
-.title {
- font-size: 40px;
- color: #000000;
- opacity: 0.9;
-}
-
-@media screen and (device-type: tablet) and (orientation: landscape) {
- .title {
- font-size: 100px;
- }
-}
-
-@media screen and (device-type: wearable) {
- .title {
- font-size: 28px;
- color: #FFFFFF;
- }
-}
-
-@media screen and (device-type: tv) {
- .container {
- background-image: url("/common/images/Wallpaper.png");
- background-size: cover;
- background-repeat: no-repeat;
- background-position: center;
- }
-
- .title {
- font-size: 100px;
- color: #FFFFFF;
- }
-}
-
-@media screen and (device-type: phone) and (orientation: landscape) {
- .title {
- font-size: 60px;
- }
-}
diff --git a/storage/storagestatfsjstest/entry/src/main/js/MainAbility/pages/index/index.hml b/storage/storagestatfsjstest/entry/src/main/js/MainAbility/pages/index/index.hml
deleted file mode 100644
index 95bd1e877b3fa9f5f4e4dc0ff608591b540d116d..0000000000000000000000000000000000000000
--- a/storage/storagestatfsjstest/entry/src/main/js/MainAbility/pages/index/index.hml
+++ /dev/null
@@ -1,19 +0,0 @@
-/*
- * Copyright (c) 2022 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-
- {{ $t('strings.hello') }} {{ title }}
-
-
diff --git a/storage/storagestatfsjstest/entry/src/main/js/MainAbility/pages/index/index.js b/storage/storagestatfsjstest/entry/src/main/js/MainAbility/pages/index/index.js
deleted file mode 100644
index f086298302bd6362b079bf99cf40dfa1e00d85e9..0000000000000000000000000000000000000000
--- a/storage/storagestatfsjstest/entry/src/main/js/MainAbility/pages/index/index.js
+++ /dev/null
@@ -1,22 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-export default {
- data: {
- title: ""
- },
- onInit() {
- this.title = this.$t('strings.world');
- }
-}
diff --git a/storage/storagestatfsjstest/entry/src/main/resources/base/element/string.json b/storage/storagestatfsjstest/entry/src/main/resources/base/element/string.json
deleted file mode 100644
index c550020f7a261df273c99a31fe8f39e77f544d97..0000000000000000000000000000000000000000
--- a/storage/storagestatfsjstest/entry/src/main/resources/base/element/string.json
+++ /dev/null
@@ -1,28 +0,0 @@
-{
- "string": [
- {
- "name": "app_name",
- "value": "Storagestatfsjstest"
- },
- {
- "name": "mainability_description",
- "value": "JS_Phone_Empty Feature Ability"
- },
- {
- "name": "MainAbility_desc",
- "value": "description"
- },
- {
- "name": "MainAbility_label",
- "value": "label"
- },
- {
- "name": "TestAbility_desc",
- "value": "description"
- },
- {
- "name": "TestAbility_label",
- "value": "label"
- }
- ]
-}
\ No newline at end of file
diff --git a/storage/storagestatfsjstest/entry/src/main/resources/base/media/icon.png b/storage/storagestatfsjstest/entry/src/main/resources/base/media/icon.png
deleted file mode 100644
index ce307a8827bd75456441ceb57d530e4c8d45d36c..0000000000000000000000000000000000000000
Binary files a/storage/storagestatfsjstest/entry/src/main/resources/base/media/icon.png and /dev/null differ
diff --git a/storage/storagestatfsjstest/entry/src/ohosTest/config.json b/storage/storagestatfsjstest/entry/src/ohosTest/config.json
deleted file mode 100644
index ed04f1f048cbac1d5fa9648f9a4d0ae5b83ed3fa..0000000000000000000000000000000000000000
--- a/storage/storagestatfsjstest/entry/src/ohosTest/config.json
+++ /dev/null
@@ -1,69 +0,0 @@
-{
- "app":{
- "bundleName":"ohos.acts.storage.statfs",
- "vendor":"example",
- "version":{
- "code":1000000,
- "name":"1.0.0"
- }
- },
- "deviceConfig":{
-
- },
- "module":{
- "package":"ohos.acts.storage.statfs_test",
- "name":".entry_test",
- "mainAbility":".TestAbility",
- "deviceType": [
- "tablet",
- "default"
- ],
- "testRunner":{
- "name":"OpenHarmonyTestRunner",
- "srcPath":"TestRunner"
- },
- "distro":{
- "deliveryWithInstall":true,
- "installationFree":true,
- "moduleName":"entry_test",
- "moduleType":"feature"
- },
- "abilities":[
- {
- "description":"$string:TestAbility_desc",
- "formsEnabled":false,
- "icon":"$media:icon",
- "label":"$string:TestAbility_label",
- "launchType":"standard",
- "name":".TestAbility",
- "orientation":"unspecified",
- "skills":[
- {
- "actions":[
- "action.system.home"
- ],
- "entities":[
- "entity.system.home"
- ]
- }
- ],
- "srcLanguage":"js",
- "srcPath":"TestAbility",
- "type":"page",
- "visible":true
- }
- ],
- "js":[
- {
- "name":".TestAbility",
- "pages":[
- "pages/index/index"
- ],
- "window":{
- "autoDesignWidth":false,
- "designWidth":720
- }
- }
- ]
- }
-}
\ No newline at end of file
diff --git a/storage/storagestatfsjstest/entry/src/ohosTest/js/TestAbility/app.js b/storage/storagestatfsjstest/entry/src/ohosTest/js/TestAbility/app.js
deleted file mode 100644
index 469c4f1380182e0dccb04f17eb95d9b503a56d29..0000000000000000000000000000000000000000
--- a/storage/storagestatfsjstest/entry/src/ohosTest/js/TestAbility/app.js
+++ /dev/null
@@ -1,33 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-import hilog from '@ohos.hilog';
-import AbilityDelegatorRegistry from '@ohos.app.ability.abilityDelegatorRegistry';
-import { Hypium } from '@ohos/hypium';
-import testsuite from '../test/List.test';
-
-export default {
- onCreate() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'TestApplication onCreate');
- var abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator()
- var abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments()
- hilog.info(0x0000, 'testTag', '%{public}s', 'start run testcase!!!');
- Hypium.hypiumTest(abilityDelegator, abilityDelegatorArguments, testsuite)
- },
- onDestroy() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'TestApplication onDestroy');
- }
-};
-
-
diff --git a/storage/storagestatfsjstest/entry/src/ohosTest/js/TestAbility/i18n/en-US.json b/storage/storagestatfsjstest/entry/src/ohosTest/js/TestAbility/i18n/en-US.json
deleted file mode 100644
index 55561b83737c3c31d082fbfa11e5fc987a351104..0000000000000000000000000000000000000000
--- a/storage/storagestatfsjstest/entry/src/ohosTest/js/TestAbility/i18n/en-US.json
+++ /dev/null
@@ -1,8 +0,0 @@
-{
- "strings": {
- "hello": "Hello",
- "world": "World"
- },
- "Files": {
- }
-}
\ No newline at end of file
diff --git a/storage/storagestatfsjstest/entry/src/ohosTest/js/TestAbility/i18n/zh-CN.json b/storage/storagestatfsjstest/entry/src/ohosTest/js/TestAbility/i18n/zh-CN.json
deleted file mode 100644
index cce1af06761a42add0cac1a0567aa3237eda8cb4..0000000000000000000000000000000000000000
--- a/storage/storagestatfsjstest/entry/src/ohosTest/js/TestAbility/i18n/zh-CN.json
+++ /dev/null
@@ -1,8 +0,0 @@
-{
- "strings": {
- "hello": "您好",
- "world": "世界"
- },
- "Files": {
- }
-}
\ No newline at end of file
diff --git a/storage/storagestatfsjstest/entry/src/ohosTest/js/TestAbility/pages/index/index.css b/storage/storagestatfsjstest/entry/src/ohosTest/js/TestAbility/pages/index/index.css
deleted file mode 100644
index b1bcd43387ba131cc1d30975ff7508a6f8084a4b..0000000000000000000000000000000000000000
--- a/storage/storagestatfsjstest/entry/src/ohosTest/js/TestAbility/pages/index/index.css
+++ /dev/null
@@ -1,30 +0,0 @@
-.container {
- display: flex;
- flex-direction: column;
- justify-content: center;
- align-items: center;
- left: 0px;
- top: 0px;
- width: 100%;
- height: 100%;
-}
-
-.title {
- font-size: 60px;
- text-align: center;
- width: 100%;
- height: 40%;
- margin: 10px;
-}
-
-@media screen and (device-type: phone) and (orientation: landscape) {
- .title {
- font-size: 60px;
- }
-}
-
-@media screen and (device-type: tablet) and (orientation: landscape) {
- .title {
- font-size: 100px;
- }
-}
\ No newline at end of file
diff --git a/storage/storagestatfsjstest/entry/src/ohosTest/js/TestAbility/pages/index/index.js b/storage/storagestatfsjstest/entry/src/ohosTest/js/TestAbility/pages/index/index.js
deleted file mode 100644
index ad113c0d214ce0d80c42c75c62d881547b6294ee..0000000000000000000000000000000000000000
--- a/storage/storagestatfsjstest/entry/src/ohosTest/js/TestAbility/pages/index/index.js
+++ /dev/null
@@ -1,25 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-export default {
- data: {
- title: ""
- },
- onInit() {
- this.title = this.$t('strings.world');
- }
-}
-
-
-
diff --git a/storage/storagestatfsjstest/entry/src/ohosTest/js/TestRunner/OpenHarmonyTestRunner.js b/storage/storagestatfsjstest/entry/src/ohosTest/js/TestRunner/OpenHarmonyTestRunner.js
deleted file mode 100644
index 03ccc5b691574b1d5bc46adefc08d9ddfc4a1f5c..0000000000000000000000000000000000000000
--- a/storage/storagestatfsjstest/entry/src/ohosTest/js/TestRunner/OpenHarmonyTestRunner.js
+++ /dev/null
@@ -1,41 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-import hilog from '@ohos.hilog';
-import AbilityDelegatorRegistry from '@ohos.app.ability.abilityDelegatorRegistry';
-
- export default {
- onPrepare() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'OpenHarmonyTestRunner OnPrepare');
- },
- onRun() {
- hilog.info(0x0000, 'testTag', '%{public}s', 'OpenHarmonyTestRunner onRun run');
- var abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments()
- var abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator()
-
- var testAbilityName = abilityDelegatorArguments.parameters['-p'] + '.TestAbility'
- var cmd = 'aa start -d 0 -a ' + testAbilityName + ' -b ' + abilityDelegatorArguments.bundleName
- var debug = abilityDelegatorArguments.parameters["-D"]
- if (debug == 'true')
- {
- cmd += ' -D'
- }
- hilog.info(0x0000, 'testTag', 'cmd : %{public}s', cmd);
- abilityDelegator.executeShellCommand(cmd, (err, data) => {
- hilog.info(0x0000, 'testTag', 'executeShellCommand : err : %{public}s', JSON.stringify(err) ?? '');
- hilog.info(0x0000, 'testTag', 'executeShellCommand : data : %{public}s', data.stdResult ?? '');
- hilog.info(0x0000, 'testTag', 'executeShellCommand : data : %{public}s', data.exitCode ?? '');
- })
- }
-};
\ No newline at end of file
diff --git a/storage/storagestatfsjstest/entry/src/ohosTest/resources/base/element/string.json b/storage/storagestatfsjstest/entry/src/ohosTest/resources/base/element/string.json
deleted file mode 100644
index c550020f7a261df273c99a31fe8f39e77f544d97..0000000000000000000000000000000000000000
--- a/storage/storagestatfsjstest/entry/src/ohosTest/resources/base/element/string.json
+++ /dev/null
@@ -1,28 +0,0 @@
-{
- "string": [
- {
- "name": "app_name",
- "value": "Storagestatfsjstest"
- },
- {
- "name": "mainability_description",
- "value": "JS_Phone_Empty Feature Ability"
- },
- {
- "name": "MainAbility_desc",
- "value": "description"
- },
- {
- "name": "MainAbility_label",
- "value": "label"
- },
- {
- "name": "TestAbility_desc",
- "value": "description"
- },
- {
- "name": "TestAbility_label",
- "value": "label"
- }
- ]
-}
\ No newline at end of file
diff --git a/storage/storagestatfsjstest/entry/src/ohosTest/resources/base/media/icon.png b/storage/storagestatfsjstest/entry/src/ohosTest/resources/base/media/icon.png
deleted file mode 100644
index ce307a8827bd75456441ceb57d530e4c8d45d36c..0000000000000000000000000000000000000000
Binary files a/storage/storagestatfsjstest/entry/src/ohosTest/resources/base/media/icon.png and /dev/null differ
diff --git a/storage/storagestatfsjstest/hvigor/hvigor-config.json5 b/storage/storagestatfsjstest/hvigor/hvigor-config.json5
deleted file mode 100644
index d1ed6c3c0cb895265a376515209a0575aeb7d898..0000000000000000000000000000000000000000
--- a/storage/storagestatfsjstest/hvigor/hvigor-config.json5
+++ /dev/null
@@ -1,20 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-{
- "hvigorVersion": "2.0.0",
- "dependencies": {
- "@ohos/hvigor-ohos-plugin": "2.0.0"
- }
-}
diff --git a/storage/storagestatfsjstest/hvigor/hvigor-wrapper.js b/storage/storagestatfsjstest/hvigor/hvigor-wrapper.js
deleted file mode 100644
index 2507619ca768432ff3fb806441f29eff47a4c4f0..0000000000000000000000000000000000000000
--- a/storage/storagestatfsjstest/hvigor/hvigor-wrapper.js
+++ /dev/null
@@ -1,16 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-"use strict";var e=require("fs"),t=require("path"),n=require("os"),r=require("crypto"),u=require("child_process"),o=require("constants"),i=require("stream"),s=require("util"),c=require("assert"),a=require("tty"),l=require("zlib"),f=require("net");function d(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var D=d(e),p=d(t),E=d(n),m=d(r),h=d(u),y=d(o),C=d(i),F=d(s),g=d(c),A=d(a),v=d(l),S=d(f),w="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{},O={},b={},_={},B=w&&w.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(_,"__esModule",{value:!0}),_.isMac=_.isLinux=_.isWindows=void 0;const P=B(E.default),k="Windows_NT",x="Linux",N="Darwin";_.isWindows=function(){return P.default.type()===k},_.isLinux=function(){return P.default.type()===x},_.isMac=function(){return P.default.type()===N};var I={},T=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),R=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),M=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)"default"!==n&&Object.prototype.hasOwnProperty.call(e,n)&&T(t,e,n);return R(t,e),t};Object.defineProperty(I,"__esModule",{value:!0}),I.hash=void 0;const L=M(m.default);I.hash=function(e,t="md5"){return L.createHash(t).update(e,"utf-8").digest("hex")},function(e){var t=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),n=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),r=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var r={};if(null!=e)for(var u in e)"default"!==u&&Object.prototype.hasOwnProperty.call(e,u)&&t(r,e,u);return n(r,e),r};Object.defineProperty(e,"__esModule",{value:!0}),e.HVIGOR_BOOT_JS_FILE_PATH=e.HVIGOR_PROJECT_DEPENDENCY_PACKAGE_JSON_PATH=e.HVIGOR_PROJECT_DEPENDENCIES_HOME=e.HVIGOR_PROJECT_WRAPPER_HOME=e.HVIGOR_PROJECT_NAME=e.HVIGOR_PROJECT_ROOT_DIR=e.HVIGOR_PROJECT_CACHES_HOME=e.HVIGOR_PNPM_STORE_PATH=e.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH=e.HVIGOR_WRAPPER_TOOLS_HOME=e.HVIGOR_USER_HOME=e.DEFAULT_PACKAGE_JSON=e.DEFAULT_HVIGOR_CONFIG_JSON_FILE_NAME=e.PNPM=e.HVIGOR=e.NPM_TOOL=e.PNPM_TOOL=e.HVIGOR_ENGINE_PACKAGE_NAME=void 0;const u=r(p.default),o=r(E.default),i=_,s=I;e.HVIGOR_ENGINE_PACKAGE_NAME="@ohos/hvigor",e.PNPM_TOOL=(0,i.isWindows)()?"pnpm.cmd":"pnpm",e.NPM_TOOL=(0,i.isWindows)()?"npm.cmd":"npm",e.HVIGOR="hvigor",e.PNPM="pnpm",e.DEFAULT_HVIGOR_CONFIG_JSON_FILE_NAME="hvigor-config.json5",e.DEFAULT_PACKAGE_JSON="package.json",e.HVIGOR_USER_HOME=u.resolve(o.homedir(),".hvigor"),e.HVIGOR_WRAPPER_TOOLS_HOME=u.resolve(e.HVIGOR_USER_HOME,"wrapper","tools"),e.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH=u.resolve(e.HVIGOR_WRAPPER_TOOLS_HOME,"node_modules",".bin",e.PNPM_TOOL),e.HVIGOR_PNPM_STORE_PATH=u.resolve(e.HVIGOR_USER_HOME,"caches"),e.HVIGOR_PROJECT_CACHES_HOME=u.resolve(e.HVIGOR_USER_HOME,"project_caches"),e.HVIGOR_PROJECT_ROOT_DIR=process.cwd(),e.HVIGOR_PROJECT_NAME=u.basename((0,s.hash)(e.HVIGOR_PROJECT_ROOT_DIR)),e.HVIGOR_PROJECT_WRAPPER_HOME=u.resolve(e.HVIGOR_PROJECT_ROOT_DIR,e.HVIGOR),e.HVIGOR_PROJECT_DEPENDENCIES_HOME=u.resolve(e.HVIGOR_PROJECT_CACHES_HOME,e.HVIGOR_PROJECT_NAME,"workspace"),e.HVIGOR_PROJECT_DEPENDENCY_PACKAGE_JSON_PATH=u.resolve(e.HVIGOR_PROJECT_DEPENDENCIES_HOME,e.DEFAULT_PACKAGE_JSON),e.HVIGOR_BOOT_JS_FILE_PATH=u.resolve(e.HVIGOR_PROJECT_DEPENDENCIES_HOME,"node_modules","@ohos","hvigor","bin","hvigor.js")}(b);var j={},$={};Object.defineProperty($,"__esModule",{value:!0}),$.logInfoPrintConsole=$.logErrorAndExit=void 0,$.logErrorAndExit=function(e){e instanceof Error?console.error(e.message):console.error(e),process.exit(-1)},$.logInfoPrintConsole=function(e){console.log(e)};var H=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),J=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),G=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)"default"!==n&&Object.prototype.hasOwnProperty.call(e,n)&&H(t,e,n);return J(t,e),t},V=w&&w.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(j,"__esModule",{value:!0}),j.isFileExists=j.offlinePluginConversion=j.executeCommand=j.getNpmPath=j.hasNpmPackInPaths=void 0;const U=h.default,W=G(p.default),z=b,K=$,q=V(D.default);j.hasNpmPackInPaths=function(e,t){try{return require.resolve(e,{paths:[...t]}),!0}catch(e){return!1}},j.getNpmPath=function(){const e=process.execPath;return W.join(W.dirname(e),z.NPM_TOOL)},j.executeCommand=function(e,t,n){0!==(0,U.spawnSync)(e,t,n).status&&(0,K.logErrorAndExit)(`Error: ${e} ${t} execute failed.See above for details.`)},j.offlinePluginConversion=function(e,t){return t.startsWith("file:")||t.endsWith(".tgz")?W.resolve(e,z.HVIGOR,t.replace("file:","")):t},j.isFileExists=function(e){return q.default.existsSync(e)&&q.default.statSync(e).isFile()},function(e){var t=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),n=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),r=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var r={};if(null!=e)for(var u in e)"default"!==u&&Object.prototype.hasOwnProperty.call(e,u)&&t(r,e,u);return n(r,e),r},u=w&&w.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(e,"__esModule",{value:!0}),e.executeInstallPnpm=e.isPnpmAvailable=e.environmentHandler=e.checkNpmConifg=e.PNPM_VERSION=void 0;const o=r(D.default),i=b,s=j,c=r(p.default),a=$,l=h.default,f=u(E.default);e.PNPM_VERSION="7.30.0",e.checkNpmConifg=function(){const e=c.resolve(i.HVIGOR_PROJECT_ROOT_DIR,".npmrc"),t=c.resolve(f.default.homedir(),".npmrc");if((0,s.isFileExists)(e)||(0,s.isFileExists)(t))return;const n=(0,s.getNpmPath)(),r=(0,l.spawnSync)(n,["config","get","prefix"],{cwd:i.HVIGOR_PROJECT_ROOT_DIR});if(0!==r.status||!r.stdout)return void(0,a.logErrorAndExit)("Error: The hvigor depends on the npmrc file. Configure the npmrc file first.");const u=c.resolve(`${r.stdout}`.replace(/[\r\n]/gi,""),".npmrc");(0,s.isFileExists)(u)||(0,a.logErrorAndExit)("Error: The hvigor depends on the npmrc file. Configure the npmrc file first.")},e.environmentHandler=function(){process.env["npm_config_update-notifier"]="false"},e.isPnpmAvailable=function(){return!!o.existsSync(i.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH)&&(0,s.hasNpmPackInPaths)("pnpm",[i.HVIGOR_WRAPPER_TOOLS_HOME])},e.executeInstallPnpm=function(){(0,a.logInfoPrintConsole)(`Installing pnpm@${e.PNPM_VERSION}...`);const t=(0,s.getNpmPath)();!function(){const t=c.resolve(i.HVIGOR_WRAPPER_TOOLS_HOME,i.DEFAULT_PACKAGE_JSON);try{o.existsSync(i.HVIGOR_WRAPPER_TOOLS_HOME)||o.mkdirSync(i.HVIGOR_WRAPPER_TOOLS_HOME,{recursive:!0});const n={dependencies:{}};n.dependencies[i.PNPM]=e.PNPM_VERSION,o.writeFileSync(t,JSON.stringify(n))}catch(e){(0,a.logErrorAndExit)(`Error: EPERM: operation not permitted,create ${t} failed.`)}}(),(0,s.executeCommand)(t,["install","pnpm"],{cwd:i.HVIGOR_WRAPPER_TOOLS_HOME,stdio:["inherit","inherit","inherit"],env:process.env}),(0,a.logInfoPrintConsole)("Pnpm install success.")}}(O);var Y={},X={},Z={},Q={};Object.defineProperty(Q,"__esModule",{value:!0}),Q.Unicode=void 0;class ee{}Q.Unicode=ee,ee.Space_Separator=/[\u1680\u2000-\u200A\u202F\u205F\u3000]/,ee.ID_Start=/[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u05D0-\u05EA\u05F0-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u0860-\u086A\u08A0-\u08B4\u08B6-\u08BD\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u09FC\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0AF9\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58-\u0C5A\u0C60\u0C61\u0C80\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D54-\u0D56\u0D5F-\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1711\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1877\u1880-\u1884\u1887-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1C80-\u1C88\u1CE9-\u1CEC\u1CEE-\u1CF1\u1CF5\u1CF6\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005-\u3007\u3021-\u3029\u3031-\u3035\u3038-\u303C\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312E\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FEA\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6EF\uA717-\uA71F\uA722-\uA788\uA78B-\uA7AE\uA7B0-\uA7B7\uA7F7-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA8FD\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uA9E0-\uA9E4\uA9E6-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB65\uAB70-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD40-\uDD74\uDE80-\uDE9C\uDEA0-\uDED0\uDF00-\uDF1F\uDF2D-\uDF4A\uDF50-\uDF75\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDCB0-\uDCD3\uDCD8-\uDCFB\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDCE0-\uDCF2\uDCF4\uDCF5\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00\uDE10-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE4\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48\uDC80-\uDCB2\uDCC0-\uDCF2]|\uD804[\uDC03-\uDC37\uDC83-\uDCAF\uDCD0-\uDCE8\uDD03-\uDD26\uDD50-\uDD72\uDD76\uDD83-\uDDB2\uDDC1-\uDDC4\uDDDA\uDDDC\uDE00-\uDE11\uDE13-\uDE2B\uDE80-\uDE86\uDE88\uDE8A-\uDE8D\uDE8F-\uDE9D\uDE9F-\uDEA8\uDEB0-\uDEDE\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3D\uDF50\uDF5D-\uDF61]|\uD805[\uDC00-\uDC34\uDC47-\uDC4A\uDC80-\uDCAF\uDCC4\uDCC5\uDCC7\uDD80-\uDDAE\uDDD8-\uDDDB\uDE00-\uDE2F\uDE44\uDE80-\uDEAA\uDF00-\uDF19]|\uD806[\uDCA0-\uDCDF\uDCFF\uDE00\uDE0B-\uDE32\uDE3A\uDE50\uDE5C-\uDE83\uDE86-\uDE89\uDEC0-\uDEF8]|\uD807[\uDC00-\uDC08\uDC0A-\uDC2E\uDC40\uDC72-\uDC8F\uDD00-\uDD06\uDD08\uDD09\uDD0B-\uDD30\uDD46]|\uD808[\uDC00-\uDF99]|\uD809[\uDC00-\uDC6E\uDC80-\uDD43]|[\uD80C\uD81C-\uD820\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD811[\uDC00-\uDE46]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDED0-\uDEED\uDF00-\uDF2F\uDF40-\uDF43\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50\uDF93-\uDF9F\uDFE0\uDFE1]|\uD821[\uDC00-\uDFEC]|\uD822[\uDC00-\uDEF2]|\uD82C[\uDC00-\uDD1E\uDD70-\uDEFB]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB]|\uD83A[\uDC00-\uDCC4\uDD00-\uDD43]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0]|\uD87E[\uDC00-\uDE1D]/,ee.ID_Continue=/[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0300-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u0483-\u0487\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u0591-\u05BD\u05BF\u05C1\u05C2\u05C4\u05C5\u05C7\u05D0-\u05EA\u05F0-\u05F2\u0610-\u061A\u0620-\u0669\u066E-\u06D3\u06D5-\u06DC\u06DF-\u06E8\u06EA-\u06FC\u06FF\u0710-\u074A\u074D-\u07B1\u07C0-\u07F5\u07FA\u0800-\u082D\u0840-\u085B\u0860-\u086A\u08A0-\u08B4\u08B6-\u08BD\u08D4-\u08E1\u08E3-\u0963\u0966-\u096F\u0971-\u0983\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BC-\u09C4\u09C7\u09C8\u09CB-\u09CE\u09D7\u09DC\u09DD\u09DF-\u09E3\u09E6-\u09F1\u09FC\u0A01-\u0A03\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A3C\u0A3E-\u0A42\u0A47\u0A48\u0A4B-\u0A4D\u0A51\u0A59-\u0A5C\u0A5E\u0A66-\u0A75\u0A81-\u0A83\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABC-\u0AC5\u0AC7-\u0AC9\u0ACB-\u0ACD\u0AD0\u0AE0-\u0AE3\u0AE6-\u0AEF\u0AF9-\u0AFF\u0B01-\u0B03\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3C-\u0B44\u0B47\u0B48\u0B4B-\u0B4D\u0B56\u0B57\u0B5C\u0B5D\u0B5F-\u0B63\u0B66-\u0B6F\u0B71\u0B82\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BBE-\u0BC2\u0BC6-\u0BC8\u0BCA-\u0BCD\u0BD0\u0BD7\u0BE6-\u0BEF\u0C00-\u0C03\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D-\u0C44\u0C46-\u0C48\u0C4A-\u0C4D\u0C55\u0C56\u0C58-\u0C5A\u0C60-\u0C63\u0C66-\u0C6F\u0C80-\u0C83\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBC-\u0CC4\u0CC6-\u0CC8\u0CCA-\u0CCD\u0CD5\u0CD6\u0CDE\u0CE0-\u0CE3\u0CE6-\u0CEF\u0CF1\u0CF2\u0D00-\u0D03\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D44\u0D46-\u0D48\u0D4A-\u0D4E\u0D54-\u0D57\u0D5F-\u0D63\u0D66-\u0D6F\u0D7A-\u0D7F\u0D82\u0D83\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0DCA\u0DCF-\u0DD4\u0DD6\u0DD8-\u0DDF\u0DE6-\u0DEF\u0DF2\u0DF3\u0E01-\u0E3A\u0E40-\u0E4E\u0E50-\u0E59\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB9\u0EBB-\u0EBD\u0EC0-\u0EC4\u0EC6\u0EC8-\u0ECD\u0ED0-\u0ED9\u0EDC-\u0EDF\u0F00\u0F18\u0F19\u0F20-\u0F29\u0F35\u0F37\u0F39\u0F3E-\u0F47\u0F49-\u0F6C\u0F71-\u0F84\u0F86-\u0F97\u0F99-\u0FBC\u0FC6\u1000-\u1049\u1050-\u109D\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u135D-\u135F\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1714\u1720-\u1734\u1740-\u1753\u1760-\u176C\u176E-\u1770\u1772\u1773\u1780-\u17D3\u17D7\u17DC\u17DD\u17E0-\u17E9\u180B-\u180D\u1810-\u1819\u1820-\u1877\u1880-\u18AA\u18B0-\u18F5\u1900-\u191E\u1920-\u192B\u1930-\u193B\u1946-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u19D0-\u19D9\u1A00-\u1A1B\u1A20-\u1A5E\u1A60-\u1A7C\u1A7F-\u1A89\u1A90-\u1A99\u1AA7\u1AB0-\u1ABD\u1B00-\u1B4B\u1B50-\u1B59\u1B6B-\u1B73\u1B80-\u1BF3\u1C00-\u1C37\u1C40-\u1C49\u1C4D-\u1C7D\u1C80-\u1C88\u1CD0-\u1CD2\u1CD4-\u1CF9\u1D00-\u1DF9\u1DFB-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u203F\u2040\u2054\u2071\u207F\u2090-\u209C\u20D0-\u20DC\u20E1\u20E5-\u20F0\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D7F-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2DE0-\u2DFF\u2E2F\u3005-\u3007\u3021-\u302F\u3031-\u3035\u3038-\u303C\u3041-\u3096\u3099\u309A\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312E\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FEA\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA62B\uA640-\uA66F\uA674-\uA67D\uA67F-\uA6F1\uA717-\uA71F\uA722-\uA788\uA78B-\uA7AE\uA7B0-\uA7B7\uA7F7-\uA827\uA840-\uA873\uA880-\uA8C5\uA8D0-\uA8D9\uA8E0-\uA8F7\uA8FB\uA8FD\uA900-\uA92D\uA930-\uA953\uA960-\uA97C\uA980-\uA9C0\uA9CF-\uA9D9\uA9E0-\uA9FE\uAA00-\uAA36\uAA40-\uAA4D\uAA50-\uAA59\uAA60-\uAA76\uAA7A-\uAAC2\uAADB-\uAADD\uAAE0-\uAAEF\uAAF2-\uAAF6\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB65\uAB70-\uABEA\uABEC\uABED\uABF0-\uABF9\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE00-\uFE0F\uFE20-\uFE2F\uFE33\uFE34\uFE4D-\uFE4F\uFE70-\uFE74\uFE76-\uFEFC\uFF10-\uFF19\uFF21-\uFF3A\uFF3F\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD40-\uDD74\uDDFD\uDE80-\uDE9C\uDEA0-\uDED0\uDEE0\uDF00-\uDF1F\uDF2D-\uDF4A\uDF50-\uDF7A\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDCA0-\uDCA9\uDCB0-\uDCD3\uDCD8-\uDCFB\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDCE0-\uDCF2\uDCF4\uDCF5\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00-\uDE03\uDE05\uDE06\uDE0C-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE38-\uDE3A\uDE3F\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE6\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48\uDC80-\uDCB2\uDCC0-\uDCF2]|\uD804[\uDC00-\uDC46\uDC66-\uDC6F\uDC7F-\uDCBA\uDCD0-\uDCE8\uDCF0-\uDCF9\uDD00-\uDD34\uDD36-\uDD3F\uDD50-\uDD73\uDD76\uDD80-\uDDC4\uDDCA-\uDDCC\uDDD0-\uDDDA\uDDDC\uDE00-\uDE11\uDE13-\uDE37\uDE3E\uDE80-\uDE86\uDE88\uDE8A-\uDE8D\uDE8F-\uDE9D\uDE9F-\uDEA8\uDEB0-\uDEEA\uDEF0-\uDEF9\uDF00-\uDF03\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3C-\uDF44\uDF47\uDF48\uDF4B-\uDF4D\uDF50\uDF57\uDF5D-\uDF63\uDF66-\uDF6C\uDF70-\uDF74]|\uD805[\uDC00-\uDC4A\uDC50-\uDC59\uDC80-\uDCC5\uDCC7\uDCD0-\uDCD9\uDD80-\uDDB5\uDDB8-\uDDC0\uDDD8-\uDDDD\uDE00-\uDE40\uDE44\uDE50-\uDE59\uDE80-\uDEB7\uDEC0-\uDEC9\uDF00-\uDF19\uDF1D-\uDF2B\uDF30-\uDF39]|\uD806[\uDCA0-\uDCE9\uDCFF\uDE00-\uDE3E\uDE47\uDE50-\uDE83\uDE86-\uDE99\uDEC0-\uDEF8]|\uD807[\uDC00-\uDC08\uDC0A-\uDC36\uDC38-\uDC40\uDC50-\uDC59\uDC72-\uDC8F\uDC92-\uDCA7\uDCA9-\uDCB6\uDD00-\uDD06\uDD08\uDD09\uDD0B-\uDD36\uDD3A\uDD3C\uDD3D\uDD3F-\uDD47\uDD50-\uDD59]|\uD808[\uDC00-\uDF99]|\uD809[\uDC00-\uDC6E\uDC80-\uDD43]|[\uD80C\uD81C-\uD820\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD811[\uDC00-\uDE46]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDE60-\uDE69\uDED0-\uDEED\uDEF0-\uDEF4\uDF00-\uDF36\uDF40-\uDF43\uDF50-\uDF59\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50-\uDF7E\uDF8F-\uDF9F\uDFE0\uDFE1]|\uD821[\uDC00-\uDFEC]|\uD822[\uDC00-\uDEF2]|\uD82C[\uDC00-\uDD1E\uDD70-\uDEFB]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99\uDC9D\uDC9E]|\uD834[\uDD65-\uDD69\uDD6D-\uDD72\uDD7B-\uDD82\uDD85-\uDD8B\uDDAA-\uDDAD\uDE42-\uDE44]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB\uDFCE-\uDFFF]|\uD836[\uDE00-\uDE36\uDE3B-\uDE6C\uDE75\uDE84\uDE9B-\uDE9F\uDEA1-\uDEAF]|\uD838[\uDC00-\uDC06\uDC08-\uDC18\uDC1B-\uDC21\uDC23\uDC24\uDC26-\uDC2A]|\uD83A[\uDC00-\uDCC4\uDCD0-\uDCD6\uDD00-\uDD4A\uDD50-\uDD59]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0]|\uD87E[\uDC00-\uDE1D]|\uDB40[\uDD00-\uDDEF]/,Object.defineProperty(Z,"__esModule",{value:!0}),Z.JudgeUtil=void 0;const te=Q;Z.JudgeUtil=class{static isIgnoreChar(e){return"string"==typeof e&&("\t"===e||"\v"===e||"\f"===e||" "===e||" "===e||"\ufeff"===e||"\n"===e||"\r"===e||"\u2028"===e||"\u2029"===e)}static isSpaceSeparator(e){return"string"==typeof e&&te.Unicode.Space_Separator.test(e)}static isIdStartChar(e){return"string"==typeof e&&(e>="a"&&e<="z"||e>="A"&&e<="Z"||"$"===e||"_"===e||te.Unicode.ID_Start.test(e))}static isIdContinueChar(e){return"string"==typeof e&&(e>="a"&&e<="z"||e>="A"&&e<="Z"||e>="0"&&e<="9"||"$"===e||"_"===e||""===e||""===e||te.Unicode.ID_Continue.test(e))}static isDigitWithoutZero(e){return/[1-9]/.test(e)}static isDigit(e){return"string"==typeof e&&/[0-9]/.test(e)}static isHexDigit(e){return"string"==typeof e&&/[0-9A-Fa-f]/.test(e)}};var ne={},re={fromCallback:function(e){return Object.defineProperty((function(...t){if("function"!=typeof t[t.length-1])return new Promise(((n,r)=>{e.call(this,...t,((e,t)=>null!=e?r(e):n(t)))}));e.apply(this,t)}),"name",{value:e.name})},fromPromise:function(e){return Object.defineProperty((function(...t){const n=t[t.length-1];if("function"!=typeof n)return e.apply(this,t);e.apply(this,t.slice(0,-1)).then((e=>n(null,e)),n)}),"name",{value:e.name})}},ue=y.default,oe=process.cwd,ie=null,se=process.env.GRACEFUL_FS_PLATFORM||process.platform;process.cwd=function(){return ie||(ie=oe.call(process)),ie};try{process.cwd()}catch(e){}if("function"==typeof process.chdir){var ce=process.chdir;process.chdir=function(e){ie=null,ce.call(process,e)},Object.setPrototypeOf&&Object.setPrototypeOf(process.chdir,ce)}var ae=function(e){ue.hasOwnProperty("O_SYMLINK")&&process.version.match(/^v0\.6\.[0-2]|^v0\.5\./)&&function(e){e.lchmod=function(t,n,r){e.open(t,ue.O_WRONLY|ue.O_SYMLINK,n,(function(t,u){t?r&&r(t):e.fchmod(u,n,(function(t){e.close(u,(function(e){r&&r(t||e)}))}))}))},e.lchmodSync=function(t,n){var r,u=e.openSync(t,ue.O_WRONLY|ue.O_SYMLINK,n),o=!0;try{r=e.fchmodSync(u,n),o=!1}finally{if(o)try{e.closeSync(u)}catch(e){}else e.closeSync(u)}return r}}(e);e.lutimes||function(e){ue.hasOwnProperty("O_SYMLINK")&&e.futimes?(e.lutimes=function(t,n,r,u){e.open(t,ue.O_SYMLINK,(function(t,o){t?u&&u(t):e.futimes(o,n,r,(function(t){e.close(o,(function(e){u&&u(t||e)}))}))}))},e.lutimesSync=function(t,n,r){var u,o=e.openSync(t,ue.O_SYMLINK),i=!0;try{u=e.futimesSync(o,n,r),i=!1}finally{if(i)try{e.closeSync(o)}catch(e){}else e.closeSync(o)}return u}):e.futimes&&(e.lutimes=function(e,t,n,r){r&&process.nextTick(r)},e.lutimesSync=function(){})}(e);e.chown=r(e.chown),e.fchown=r(e.fchown),e.lchown=r(e.lchown),e.chmod=t(e.chmod),e.fchmod=t(e.fchmod),e.lchmod=t(e.lchmod),e.chownSync=u(e.chownSync),e.fchownSync=u(e.fchownSync),e.lchownSync=u(e.lchownSync),e.chmodSync=n(e.chmodSync),e.fchmodSync=n(e.fchmodSync),e.lchmodSync=n(e.lchmodSync),e.stat=o(e.stat),e.fstat=o(e.fstat),e.lstat=o(e.lstat),e.statSync=i(e.statSync),e.fstatSync=i(e.fstatSync),e.lstatSync=i(e.lstatSync),e.chmod&&!e.lchmod&&(e.lchmod=function(e,t,n){n&&process.nextTick(n)},e.lchmodSync=function(){});e.chown&&!e.lchown&&(e.lchown=function(e,t,n,r){r&&process.nextTick(r)},e.lchownSync=function(){});"win32"===se&&(e.rename="function"!=typeof e.rename?e.rename:function(t){function n(n,r,u){var o=Date.now(),i=0;t(n,r,(function s(c){if(c&&("EACCES"===c.code||"EPERM"===c.code||"EBUSY"===c.code)&&Date.now()-o<6e4)return setTimeout((function(){e.stat(r,(function(e,o){e&&"ENOENT"===e.code?t(n,r,s):u(c)}))}),i),void(i<100&&(i+=10));u&&u(c)}))}return Object.setPrototypeOf&&Object.setPrototypeOf(n,t),n}(e.rename));function t(t){return t?function(n,r,u){return t.call(e,n,r,(function(e){s(e)&&(e=null),u&&u.apply(this,arguments)}))}:t}function n(t){return t?function(n,r){try{return t.call(e,n,r)}catch(e){if(!s(e))throw e}}:t}function r(t){return t?function(n,r,u,o){return t.call(e,n,r,u,(function(e){s(e)&&(e=null),o&&o.apply(this,arguments)}))}:t}function u(t){return t?function(n,r,u){try{return t.call(e,n,r,u)}catch(e){if(!s(e))throw e}}:t}function o(t){return t?function(n,r,u){function o(e,t){t&&(t.uid<0&&(t.uid+=4294967296),t.gid<0&&(t.gid+=4294967296)),u&&u.apply(this,arguments)}return"function"==typeof r&&(u=r,r=null),r?t.call(e,n,r,o):t.call(e,n,o)}:t}function i(t){return t?function(n,r){var u=r?t.call(e,n,r):t.call(e,n);return u&&(u.uid<0&&(u.uid+=4294967296),u.gid<0&&(u.gid+=4294967296)),u}:t}function s(e){return!e||("ENOSYS"===e.code||!(process.getuid&&0===process.getuid()||"EINVAL"!==e.code&&"EPERM"!==e.code))}e.read="function"!=typeof e.read?e.read:function(t){function n(n,r,u,o,i,s){var c;if(s&&"function"==typeof s){var a=0;c=function(l,f,d){if(l&&"EAGAIN"===l.code&&a<10)return a++,t.call(e,n,r,u,o,i,c);s.apply(this,arguments)}}return t.call(e,n,r,u,o,i,c)}return Object.setPrototypeOf&&Object.setPrototypeOf(n,t),n}(e.read),e.readSync="function"!=typeof e.readSync?e.readSync:(c=e.readSync,function(t,n,r,u,o){for(var i=0;;)try{return c.call(e,t,n,r,u,o)}catch(e){if("EAGAIN"===e.code&&i<10){i++;continue}throw e}});var c};var le=C.default.Stream,fe=function(e){return{ReadStream:function t(n,r){if(!(this instanceof t))return new t(n,r);le.call(this);var u=this;this.path=n,this.fd=null,this.readable=!0,this.paused=!1,this.flags="r",this.mode=438,this.bufferSize=65536,r=r||{};for(var o=Object.keys(r),i=0,s=o.length;ithis.end)throw new Error("start must be <= end");this.pos=this.start}if(null!==this.fd)return void process.nextTick((function(){u._read()}));e.open(this.path,this.flags,this.mode,(function(e,t){if(e)return u.emit("error",e),void(u.readable=!1);u.fd=t,u.emit("open",t),u._read()}))},WriteStream:function t(n,r){if(!(this instanceof t))return new t(n,r);le.call(this),this.path=n,this.fd=null,this.writable=!0,this.flags="w",this.encoding="binary",this.mode=438,this.bytesWritten=0,r=r||{};for(var u=Object.keys(r),o=0,i=u.length;o= zero");this.pos=this.start}this.busy=!1,this._queue=[],null===this.fd&&(this._open=e.open,this._queue.push([this._open,this.path,this.flags,this.mode,void 0]),this.flush())}}};var de=function(e){if(null===e||"object"!=typeof e)return e;if(e instanceof Object)var t={__proto__:De(e)};else t=Object.create(null);return Object.getOwnPropertyNames(e).forEach((function(n){Object.defineProperty(t,n,Object.getOwnPropertyDescriptor(e,n))})),t},De=Object.getPrototypeOf||function(e){return e.__proto__};var pe,Ee,me=D.default,he=ae,ye=fe,Ce=de,Fe=F.default;function ge(e,t){Object.defineProperty(e,pe,{get:function(){return t}})}"function"==typeof Symbol&&"function"==typeof Symbol.for?(pe=Symbol.for("graceful-fs.queue"),Ee=Symbol.for("graceful-fs.previous")):(pe="___graceful-fs.queue",Ee="___graceful-fs.previous");var Ae=function(){};if(Fe.debuglog?Ae=Fe.debuglog("gfs4"):/\bgfs4\b/i.test(process.env.NODE_DEBUG||"")&&(Ae=function(){var e=Fe.format.apply(Fe,arguments);e="GFS4: "+e.split(/\n/).join("\nGFS4: "),console.error(e)}),!me[pe]){var ve=w[pe]||[];ge(me,ve),me.close=function(e){function t(t,n){return e.call(me,t,(function(e){e||_e(),"function"==typeof n&&n.apply(this,arguments)}))}return Object.defineProperty(t,Ee,{value:e}),t}(me.close),me.closeSync=function(e){function t(t){e.apply(me,arguments),_e()}return Object.defineProperty(t,Ee,{value:e}),t}(me.closeSync),/\bgfs4\b/i.test(process.env.NODE_DEBUG||"")&&process.on("exit",(function(){Ae(me[pe]),g.default.equal(me[pe].length,0)}))}w[pe]||ge(w,me[pe]);var Se,we=Oe(Ce(me));function Oe(e){he(e),e.gracefulify=Oe,e.createReadStream=function(t,n){return new e.ReadStream(t,n)},e.createWriteStream=function(t,n){return new e.WriteStream(t,n)};var t=e.readFile;e.readFile=function(e,n,r){"function"==typeof n&&(r=n,n=null);return function e(n,r,u,o){return t(n,r,(function(t){!t||"EMFILE"!==t.code&&"ENFILE"!==t.code?"function"==typeof u&&u.apply(this,arguments):be([e,[n,r,u],t,o||Date.now(),Date.now()])}))}(e,n,r)};var n=e.writeFile;e.writeFile=function(e,t,r,u){"function"==typeof r&&(u=r,r=null);return function e(t,r,u,o,i){return n(t,r,u,(function(n){!n||"EMFILE"!==n.code&&"ENFILE"!==n.code?"function"==typeof o&&o.apply(this,arguments):be([e,[t,r,u,o],n,i||Date.now(),Date.now()])}))}(e,t,r,u)};var r=e.appendFile;r&&(e.appendFile=function(e,t,n,u){"function"==typeof n&&(u=n,n=null);return function e(t,n,u,o,i){return r(t,n,u,(function(r){!r||"EMFILE"!==r.code&&"ENFILE"!==r.code?"function"==typeof o&&o.apply(this,arguments):be([e,[t,n,u,o],r,i||Date.now(),Date.now()])}))}(e,t,n,u)});var u=e.copyFile;u&&(e.copyFile=function(e,t,n,r){"function"==typeof n&&(r=n,n=0);return function e(t,n,r,o,i){return u(t,n,r,(function(u){!u||"EMFILE"!==u.code&&"ENFILE"!==u.code?"function"==typeof o&&o.apply(this,arguments):be([e,[t,n,r,o],u,i||Date.now(),Date.now()])}))}(e,t,n,r)});var o=e.readdir;e.readdir=function(e,t,n){"function"==typeof t&&(n=t,t=null);var r=i.test(process.version)?function(e,t,n,r){return o(e,u(e,t,n,r))}:function(e,t,n,r){return o(e,t,u(e,t,n,r))};return r(e,t,n);function u(e,t,n,u){return function(o,i){!o||"EMFILE"!==o.code&&"ENFILE"!==o.code?(i&&i.sort&&i.sort(),"function"==typeof n&&n.call(this,o,i)):be([r,[e,t,n],o,u||Date.now(),Date.now()])}}};var i=/^v[0-5]\./;if("v0.8"===process.version.substr(0,4)){var s=ye(e);d=s.ReadStream,D=s.WriteStream}var c=e.ReadStream;c&&(d.prototype=Object.create(c.prototype),d.prototype.open=function(){var e=this;E(e.path,e.flags,e.mode,(function(t,n){t?(e.autoClose&&e.destroy(),e.emit("error",t)):(e.fd=n,e.emit("open",n),e.read())}))});var a=e.WriteStream;a&&(D.prototype=Object.create(a.prototype),D.prototype.open=function(){var e=this;E(e.path,e.flags,e.mode,(function(t,n){t?(e.destroy(),e.emit("error",t)):(e.fd=n,e.emit("open",n))}))}),Object.defineProperty(e,"ReadStream",{get:function(){return d},set:function(e){d=e},enumerable:!0,configurable:!0}),Object.defineProperty(e,"WriteStream",{get:function(){return D},set:function(e){D=e},enumerable:!0,configurable:!0});var l=d;Object.defineProperty(e,"FileReadStream",{get:function(){return l},set:function(e){l=e},enumerable:!0,configurable:!0});var f=D;function d(e,t){return this instanceof d?(c.apply(this,arguments),this):d.apply(Object.create(d.prototype),arguments)}function D(e,t){return this instanceof D?(a.apply(this,arguments),this):D.apply(Object.create(D.prototype),arguments)}Object.defineProperty(e,"FileWriteStream",{get:function(){return f},set:function(e){f=e},enumerable:!0,configurable:!0});var p=e.open;function E(e,t,n,r){return"function"==typeof n&&(r=n,n=null),function e(t,n,r,u,o){return p(t,n,r,(function(i,s){!i||"EMFILE"!==i.code&&"ENFILE"!==i.code?"function"==typeof u&&u.apply(this,arguments):be([e,[t,n,r,u],i,o||Date.now(),Date.now()])}))}(e,t,n,r)}return e.open=E,e}function be(e){Ae("ENQUEUE",e[0].name,e[1]),me[pe].push(e),Be()}function _e(){for(var e=Date.now(),t=0;t2&&(me[pe][t][3]=e,me[pe][t][4]=e);Be()}function Be(){if(clearTimeout(Se),Se=void 0,0!==me[pe].length){var e=me[pe].shift(),t=e[0],n=e[1],r=e[2],u=e[3],o=e[4];if(void 0===u)Ae("RETRY",t.name,n),t.apply(null,n);else if(Date.now()-u>=6e4){Ae("TIMEOUT",t.name,n);var i=n.pop();"function"==typeof i&&i.call(null,r)}else{var s=Date.now()-o,c=Math.max(o-u,1);s>=Math.min(1.2*c,100)?(Ae("RETRY",t.name,n),t.apply(null,n.concat([u]))):me[pe].push(e)}void 0===Se&&(Se=setTimeout(Be,0))}}process.env.TEST_GRACEFUL_FS_GLOBAL_PATCH&&!me.__patched&&(we=Oe(me),me.__patched=!0),function(e){const t=re.fromCallback,n=we,r=["access","appendFile","chmod","chown","close","copyFile","fchmod","fchown","fdatasync","fstat","fsync","ftruncate","futimes","lchmod","lchown","link","lstat","mkdir","mkdtemp","open","opendir","readdir","readFile","readlink","realpath","rename","rm","rmdir","stat","symlink","truncate","unlink","utimes","writeFile"].filter((e=>"function"==typeof n[e]));Object.assign(e,n),r.forEach((r=>{e[r]=t(n[r])})),e.realpath.native=t(n.realpath.native),e.exists=function(e,t){return"function"==typeof t?n.exists(e,t):new Promise((t=>n.exists(e,t)))},e.read=function(e,t,r,u,o,i){return"function"==typeof i?n.read(e,t,r,u,o,i):new Promise(((i,s)=>{n.read(e,t,r,u,o,((e,t,n)=>{if(e)return s(e);i({bytesRead:t,buffer:n})}))}))},e.write=function(e,t,...r){return"function"==typeof r[r.length-1]?n.write(e,t,...r):new Promise(((u,o)=>{n.write(e,t,...r,((e,t,n)=>{if(e)return o(e);u({bytesWritten:t,buffer:n})}))}))},"function"==typeof n.writev&&(e.writev=function(e,t,...r){return"function"==typeof r[r.length-1]?n.writev(e,t,...r):new Promise(((u,o)=>{n.writev(e,t,...r,((e,t,n)=>{if(e)return o(e);u({bytesWritten:t,buffers:n})}))}))})}(ne);var Pe={},ke={};const xe=p.default;ke.checkPath=function(e){if("win32"===process.platform){if(/[<>:"|?*]/.test(e.replace(xe.parse(e).root,""))){const t=new Error(`Path contains invalid characters: ${e}`);throw t.code="EINVAL",t}}};const Ne=ne,{checkPath:Ie}=ke,Te=e=>"number"==typeof e?e:{mode:511,...e}.mode;Pe.makeDir=async(e,t)=>(Ie(e),Ne.mkdir(e,{mode:Te(t),recursive:!0})),Pe.makeDirSync=(e,t)=>(Ie(e),Ne.mkdirSync(e,{mode:Te(t),recursive:!0}));const Re=re.fromPromise,{makeDir:Me,makeDirSync:Le}=Pe,je=Re(Me);var $e={mkdirs:je,mkdirsSync:Le,mkdirp:je,mkdirpSync:Le,ensureDir:je,ensureDirSync:Le};const He=re.fromPromise,Je=ne;var Ge={pathExists:He((function(e){return Je.access(e).then((()=>!0)).catch((()=>!1))})),pathExistsSync:Je.existsSync};const Ve=we;var Ue=function(e,t,n,r){Ve.open(e,"r+",((e,u)=>{if(e)return r(e);Ve.futimes(u,t,n,(e=>{Ve.close(u,(t=>{r&&r(e||t)}))}))}))},We=function(e,t,n){const r=Ve.openSync(e,"r+");return Ve.futimesSync(r,t,n),Ve.closeSync(r)};const ze=ne,Ke=p.default,qe=F.default;function Ye(e,t,n){const r=n.dereference?e=>ze.stat(e,{bigint:!0}):e=>ze.lstat(e,{bigint:!0});return Promise.all([r(e),r(t).catch((e=>{if("ENOENT"===e.code)return null;throw e}))]).then((([e,t])=>({srcStat:e,destStat:t})))}function Xe(e,t){return t.ino&&t.dev&&t.ino===e.ino&&t.dev===e.dev}function Ze(e,t){const n=Ke.resolve(e).split(Ke.sep).filter((e=>e)),r=Ke.resolve(t).split(Ke.sep).filter((e=>e));return n.reduce(((e,t,n)=>e&&r[n]===t),!0)}function Qe(e,t,n){return`Cannot ${n} '${e}' to a subdirectory of itself, '${t}'.`}var et={checkPaths:function(e,t,n,r,u){qe.callbackify(Ye)(e,t,r,((r,o)=>{if(r)return u(r);const{srcStat:i,destStat:s}=o;if(s){if(Xe(i,s)){const r=Ke.basename(e),o=Ke.basename(t);return"move"===n&&r!==o&&r.toLowerCase()===o.toLowerCase()?u(null,{srcStat:i,destStat:s,isChangingCase:!0}):u(new Error("Source and destination must not be the same."))}if(i.isDirectory()&&!s.isDirectory())return u(new Error(`Cannot overwrite non-directory '${t}' with directory '${e}'.`));if(!i.isDirectory()&&s.isDirectory())return u(new Error(`Cannot overwrite directory '${t}' with non-directory '${e}'.`))}return i.isDirectory()&&Ze(e,t)?u(new Error(Qe(e,t,n))):u(null,{srcStat:i,destStat:s})}))},checkPathsSync:function(e,t,n,r){const{srcStat:u,destStat:o}=function(e,t,n){let r;const u=n.dereference?e=>ze.statSync(e,{bigint:!0}):e=>ze.lstatSync(e,{bigint:!0}),o=u(e);try{r=u(t)}catch(e){if("ENOENT"===e.code)return{srcStat:o,destStat:null};throw e}return{srcStat:o,destStat:r}}(e,t,r);if(o){if(Xe(u,o)){const r=Ke.basename(e),i=Ke.basename(t);if("move"===n&&r!==i&&r.toLowerCase()===i.toLowerCase())return{srcStat:u,destStat:o,isChangingCase:!0};throw new Error("Source and destination must not be the same.")}if(u.isDirectory()&&!o.isDirectory())throw new Error(`Cannot overwrite non-directory '${t}' with directory '${e}'.`);if(!u.isDirectory()&&o.isDirectory())throw new Error(`Cannot overwrite directory '${t}' with non-directory '${e}'.`)}if(u.isDirectory()&&Ze(e,t))throw new Error(Qe(e,t,n));return{srcStat:u,destStat:o}},checkParentPaths:function e(t,n,r,u,o){const i=Ke.resolve(Ke.dirname(t)),s=Ke.resolve(Ke.dirname(r));if(s===i||s===Ke.parse(s).root)return o();ze.stat(s,{bigint:!0},((i,c)=>i?"ENOENT"===i.code?o():o(i):Xe(n,c)?o(new Error(Qe(t,r,u))):e(t,n,s,u,o)))},checkParentPathsSync:function e(t,n,r,u){const o=Ke.resolve(Ke.dirname(t)),i=Ke.resolve(Ke.dirname(r));if(i===o||i===Ke.parse(i).root)return;let s;try{s=ze.statSync(i,{bigint:!0})}catch(e){if("ENOENT"===e.code)return;throw e}if(Xe(n,s))throw new Error(Qe(t,r,u));return e(t,n,i,u)},isSrcSubdir:Ze,areIdentical:Xe};const tt=we,nt=p.default,rt=$e.mkdirs,ut=Ge.pathExists,ot=Ue,it=et;function st(e,t,n,r,u){const o=nt.dirname(n);ut(o,((i,s)=>i?u(i):s?at(e,t,n,r,u):void rt(o,(o=>o?u(o):at(e,t,n,r,u)))))}function ct(e,t,n,r,u,o){Promise.resolve(u.filter(n,r)).then((i=>i?e(t,n,r,u,o):o()),(e=>o(e)))}function at(e,t,n,r,u){(r.dereference?tt.stat:tt.lstat)(t,((o,i)=>o?u(o):i.isDirectory()?function(e,t,n,r,u,o){return t?Dt(n,r,u,o):function(e,t,n,r,u){tt.mkdir(n,(o=>{if(o)return u(o);Dt(t,n,r,(t=>t?u(t):dt(n,e,u)))}))}(e.mode,n,r,u,o)}(i,e,t,n,r,u):i.isFile()||i.isCharacterDevice()||i.isBlockDevice()?function(e,t,n,r,u,o){return t?function(e,t,n,r,u){if(!r.overwrite)return r.errorOnExist?u(new Error(`'${n}' already exists`)):u();tt.unlink(n,(o=>o?u(o):lt(e,t,n,r,u)))}(e,n,r,u,o):lt(e,n,r,u,o)}(i,e,t,n,r,u):i.isSymbolicLink()?function(e,t,n,r,u){tt.readlink(t,((t,o)=>t?u(t):(r.dereference&&(o=nt.resolve(process.cwd(),o)),e?void tt.readlink(n,((t,i)=>t?"EINVAL"===t.code||"UNKNOWN"===t.code?tt.symlink(o,n,u):u(t):(r.dereference&&(i=nt.resolve(process.cwd(),i)),it.isSrcSubdir(o,i)?u(new Error(`Cannot copy '${o}' to a subdirectory of itself, '${i}'.`)):e.isDirectory()&&it.isSrcSubdir(i,o)?u(new Error(`Cannot overwrite '${i}' with '${o}'.`)):function(e,t,n){tt.unlink(t,(r=>r?n(r):tt.symlink(e,t,n)))}(o,n,u)))):tt.symlink(o,n,u))))}(e,t,n,r,u):i.isSocket()?u(new Error(`Cannot copy a socket file: ${t}`)):i.isFIFO()?u(new Error(`Cannot copy a FIFO pipe: ${t}`)):u(new Error(`Unknown file: ${t}`))))}function lt(e,t,n,r,u){tt.copyFile(t,n,(o=>o?u(o):r.preserveTimestamps?function(e,t,n,r){if(function(e){return 0==(128&e)}(e))return function(e,t,n){return dt(e,128|t,n)}(n,e,(u=>u?r(u):ft(e,t,n,r)));return ft(e,t,n,r)}(e.mode,t,n,u):dt(n,e.mode,u)))}function ft(e,t,n,r){!function(e,t,n){tt.stat(e,((e,r)=>e?n(e):ot(t,r.atime,r.mtime,n)))}(t,n,(t=>t?r(t):dt(n,e,r)))}function dt(e,t,n){return tt.chmod(e,t,n)}function Dt(e,t,n,r){tt.readdir(e,((u,o)=>u?r(u):pt(o,e,t,n,r)))}function pt(e,t,n,r,u){const o=e.pop();return o?function(e,t,n,r,u,o){const i=nt.join(n,t),s=nt.join(r,t);it.checkPaths(i,s,"copy",u,((t,c)=>{if(t)return o(t);const{destStat:a}=c;!function(e,t,n,r,u){r.filter?ct(at,e,t,n,r,u):at(e,t,n,r,u)}(a,i,s,u,(t=>t?o(t):pt(e,n,r,u,o)))}))}(e,o,t,n,r,u):u()}var Et=function(e,t,n,r){"function"!=typeof n||r?"function"==typeof n&&(n={filter:n}):(r=n,n={}),r=r||function(){},(n=n||{}).clobber=!("clobber"in n)||!!n.clobber,n.overwrite="overwrite"in n?!!n.overwrite:n.clobber,n.preserveTimestamps&&"ia32"===process.arch&&console.warn("fs-extra: Using the preserveTimestamps option in 32-bit node is not recommended;\n\n see https://github.com/jprichardson/node-fs-extra/issues/269"),it.checkPaths(e,t,"copy",n,((u,o)=>{if(u)return r(u);const{srcStat:i,destStat:s}=o;it.checkParentPaths(e,i,t,"copy",(u=>u?r(u):n.filter?ct(st,s,e,t,n,r):st(s,e,t,n,r)))}))};const mt=we,ht=p.default,yt=$e.mkdirsSync,Ct=We,Ft=et;function gt(e,t,n,r){const u=(r.dereference?mt.statSync:mt.lstatSync)(t);if(u.isDirectory())return function(e,t,n,r,u){return t?St(n,r,u):function(e,t,n,r){return mt.mkdirSync(n),St(t,n,r),vt(n,e)}(e.mode,n,r,u)}(u,e,t,n,r);if(u.isFile()||u.isCharacterDevice()||u.isBlockDevice())return function(e,t,n,r,u){return t?function(e,t,n,r){if(r.overwrite)return mt.unlinkSync(n),At(e,t,n,r);if(r.errorOnExist)throw new Error(`'${n}' already exists`)}(e,n,r,u):At(e,n,r,u)}(u,e,t,n,r);if(u.isSymbolicLink())return function(e,t,n,r){let u=mt.readlinkSync(t);r.dereference&&(u=ht.resolve(process.cwd(),u));if(e){let e;try{e=mt.readlinkSync(n)}catch(e){if("EINVAL"===e.code||"UNKNOWN"===e.code)return mt.symlinkSync(u,n);throw e}if(r.dereference&&(e=ht.resolve(process.cwd(),e)),Ft.isSrcSubdir(u,e))throw new Error(`Cannot copy '${u}' to a subdirectory of itself, '${e}'.`);if(mt.statSync(n).isDirectory()&&Ft.isSrcSubdir(e,u))throw new Error(`Cannot overwrite '${e}' with '${u}'.`);return function(e,t){return mt.unlinkSync(t),mt.symlinkSync(e,t)}(u,n)}return mt.symlinkSync(u,n)}(e,t,n,r);if(u.isSocket())throw new Error(`Cannot copy a socket file: ${t}`);if(u.isFIFO())throw new Error(`Cannot copy a FIFO pipe: ${t}`);throw new Error(`Unknown file: ${t}`)}function At(e,t,n,r){return mt.copyFileSync(t,n),r.preserveTimestamps&&function(e,t,n){(function(e){return 0==(128&e)})(e)&&function(e,t){vt(e,128|t)}(n,e);(function(e,t){const n=mt.statSync(e);Ct(t,n.atime,n.mtime)})(t,n)}(e.mode,t,n),vt(n,e.mode)}function vt(e,t){return mt.chmodSync(e,t)}function St(e,t,n){mt.readdirSync(e).forEach((r=>function(e,t,n,r){const u=ht.join(t,e),o=ht.join(n,e),{destStat:i}=Ft.checkPathsSync(u,o,"copy",r);return function(e,t,n,r){if(!r.filter||r.filter(t,n))return gt(e,t,n,r)}(i,u,o,r)}(r,e,t,n)))}var wt=function(e,t,n){"function"==typeof n&&(n={filter:n}),(n=n||{}).clobber=!("clobber"in n)||!!n.clobber,n.overwrite="overwrite"in n?!!n.overwrite:n.clobber,n.preserveTimestamps&&"ia32"===process.arch&&console.warn("fs-extra: Using the preserveTimestamps option in 32-bit node is not recommended;\n\n see https://github.com/jprichardson/node-fs-extra/issues/269");const{srcStat:r,destStat:u}=Ft.checkPathsSync(e,t,"copy",n);return Ft.checkParentPathsSync(e,r,t,"copy"),function(e,t,n,r){if(r.filter&&!r.filter(t,n))return;const u=ht.dirname(n);mt.existsSync(u)||yt(u);return gt(e,t,n,r)}(u,e,t,n)};var Ot={copy:(0,re.fromCallback)(Et),copySync:wt};const bt=we,_t=p.default,Bt=g.default,Pt="win32"===process.platform;function kt(e){["unlink","chmod","stat","lstat","rmdir","readdir"].forEach((t=>{e[t]=e[t]||bt[t],e[t+="Sync"]=e[t]||bt[t]})),e.maxBusyTries=e.maxBusyTries||3}function xt(e,t,n){let r=0;"function"==typeof t&&(n=t,t={}),Bt(e,"rimraf: missing path"),Bt.strictEqual(typeof e,"string","rimraf: path should be a string"),Bt.strictEqual(typeof n,"function","rimraf: callback function required"),Bt(t,"rimraf: invalid options argument provided"),Bt.strictEqual(typeof t,"object","rimraf: options should be object"),kt(t),Nt(e,t,(function u(o){if(o){if(("EBUSY"===o.code||"ENOTEMPTY"===o.code||"EPERM"===o.code)&&rNt(e,t,u)),100*r)}"ENOENT"===o.code&&(o=null)}n(o)}))}function Nt(e,t,n){Bt(e),Bt(t),Bt("function"==typeof n),t.lstat(e,((r,u)=>r&&"ENOENT"===r.code?n(null):r&&"EPERM"===r.code&&Pt?It(e,t,r,n):u&&u.isDirectory()?Rt(e,t,r,n):void t.unlink(e,(r=>{if(r){if("ENOENT"===r.code)return n(null);if("EPERM"===r.code)return Pt?It(e,t,r,n):Rt(e,t,r,n);if("EISDIR"===r.code)return Rt(e,t,r,n)}return n(r)}))))}function It(e,t,n,r){Bt(e),Bt(t),Bt("function"==typeof r),t.chmod(e,438,(u=>{u?r("ENOENT"===u.code?null:n):t.stat(e,((u,o)=>{u?r("ENOENT"===u.code?null:n):o.isDirectory()?Rt(e,t,n,r):t.unlink(e,r)}))}))}function Tt(e,t,n){let r;Bt(e),Bt(t);try{t.chmodSync(e,438)}catch(e){if("ENOENT"===e.code)return;throw n}try{r=t.statSync(e)}catch(e){if("ENOENT"===e.code)return;throw n}r.isDirectory()?Lt(e,t,n):t.unlinkSync(e)}function Rt(e,t,n,r){Bt(e),Bt(t),Bt("function"==typeof r),t.rmdir(e,(u=>{!u||"ENOTEMPTY"!==u.code&&"EEXIST"!==u.code&&"EPERM"!==u.code?u&&"ENOTDIR"===u.code?r(n):r(u):function(e,t,n){Bt(e),Bt(t),Bt("function"==typeof n),t.readdir(e,((r,u)=>{if(r)return n(r);let o,i=u.length;if(0===i)return t.rmdir(e,n);u.forEach((r=>{xt(_t.join(e,r),t,(r=>{if(!o)return r?n(o=r):void(0==--i&&t.rmdir(e,n))}))}))}))}(e,t,r)}))}function Mt(e,t){let n;kt(t=t||{}),Bt(e,"rimraf: missing path"),Bt.strictEqual(typeof e,"string","rimraf: path should be a string"),Bt(t,"rimraf: missing options"),Bt.strictEqual(typeof t,"object","rimraf: options should be object");try{n=t.lstatSync(e)}catch(n){if("ENOENT"===n.code)return;"EPERM"===n.code&&Pt&&Tt(e,t,n)}try{n&&n.isDirectory()?Lt(e,t,null):t.unlinkSync(e)}catch(n){if("ENOENT"===n.code)return;if("EPERM"===n.code)return Pt?Tt(e,t,n):Lt(e,t,n);if("EISDIR"!==n.code)throw n;Lt(e,t,n)}}function Lt(e,t,n){Bt(e),Bt(t);try{t.rmdirSync(e)}catch(r){if("ENOTDIR"===r.code)throw n;if("ENOTEMPTY"===r.code||"EEXIST"===r.code||"EPERM"===r.code)!function(e,t){if(Bt(e),Bt(t),t.readdirSync(e).forEach((n=>Mt(_t.join(e,n),t))),!Pt){return t.rmdirSync(e,t)}{const n=Date.now();do{try{return t.rmdirSync(e,t)}catch{}}while(Date.now()-n<500)}}(e,t);else if("ENOENT"!==r.code)throw r}}var jt=xt;xt.sync=Mt;const $t=we,Ht=re.fromCallback,Jt=jt;var Gt={remove:Ht((function(e,t){if($t.rm)return $t.rm(e,{recursive:!0,force:!0},t);Jt(e,t)})),removeSync:function(e){if($t.rmSync)return $t.rmSync(e,{recursive:!0,force:!0});Jt.sync(e)}};const Vt=re.fromPromise,Ut=ne,Wt=p.default,zt=$e,Kt=Gt,qt=Vt((async function(e){let t;try{t=await Ut.readdir(e)}catch{return zt.mkdirs(e)}return Promise.all(t.map((t=>Kt.remove(Wt.join(e,t)))))}));function Yt(e){let t;try{t=Ut.readdirSync(e)}catch{return zt.mkdirsSync(e)}t.forEach((t=>{t=Wt.join(e,t),Kt.removeSync(t)}))}var Xt={emptyDirSync:Yt,emptydirSync:Yt,emptyDir:qt,emptydir:qt};const Zt=re.fromCallback,Qt=p.default,en=we,tn=$e;var nn={createFile:Zt((function(e,t){function n(){en.writeFile(e,"",(e=>{if(e)return t(e);t()}))}en.stat(e,((r,u)=>{if(!r&&u.isFile())return t();const o=Qt.dirname(e);en.stat(o,((e,r)=>{if(e)return"ENOENT"===e.code?tn.mkdirs(o,(e=>{if(e)return t(e);n()})):t(e);r.isDirectory()?n():en.readdir(o,(e=>{if(e)return t(e)}))}))}))})),createFileSync:function(e){let t;try{t=en.statSync(e)}catch{}if(t&&t.isFile())return;const n=Qt.dirname(e);try{en.statSync(n).isDirectory()||en.readdirSync(n)}catch(e){if(!e||"ENOENT"!==e.code)throw e;tn.mkdirsSync(n)}en.writeFileSync(e,"")}};const rn=re.fromCallback,un=p.default,on=we,sn=$e,cn=Ge.pathExists,{areIdentical:an}=et;var ln={createLink:rn((function(e,t,n){function r(e,t){on.link(e,t,(e=>{if(e)return n(e);n(null)}))}on.lstat(t,((u,o)=>{on.lstat(e,((u,i)=>{if(u)return u.message=u.message.replace("lstat","ensureLink"),n(u);if(o&&an(i,o))return n(null);const s=un.dirname(t);cn(s,((u,o)=>u?n(u):o?r(e,t):void sn.mkdirs(s,(u=>{if(u)return n(u);r(e,t)}))))}))}))})),createLinkSync:function(e,t){let n;try{n=on.lstatSync(t)}catch{}try{const t=on.lstatSync(e);if(n&&an(t,n))return}catch(e){throw e.message=e.message.replace("lstat","ensureLink"),e}const r=un.dirname(t);return on.existsSync(r)||sn.mkdirsSync(r),on.linkSync(e,t)}};const fn=p.default,dn=we,Dn=Ge.pathExists;var pn={symlinkPaths:function(e,t,n){if(fn.isAbsolute(e))return dn.lstat(e,(t=>t?(t.message=t.message.replace("lstat","ensureSymlink"),n(t)):n(null,{toCwd:e,toDst:e})));{const r=fn.dirname(t),u=fn.join(r,e);return Dn(u,((t,o)=>t?n(t):o?n(null,{toCwd:u,toDst:e}):dn.lstat(e,(t=>t?(t.message=t.message.replace("lstat","ensureSymlink"),n(t)):n(null,{toCwd:e,toDst:fn.relative(r,e)})))))}},symlinkPathsSync:function(e,t){let n;if(fn.isAbsolute(e)){if(n=dn.existsSync(e),!n)throw new Error("absolute srcpath does not exist");return{toCwd:e,toDst:e}}{const r=fn.dirname(t),u=fn.join(r,e);if(n=dn.existsSync(u),n)return{toCwd:u,toDst:e};if(n=dn.existsSync(e),!n)throw new Error("relative srcpath does not exist");return{toCwd:e,toDst:fn.relative(r,e)}}}};const En=we;var mn={symlinkType:function(e,t,n){if(n="function"==typeof t?t:n,t="function"!=typeof t&&t)return n(null,t);En.lstat(e,((e,r)=>{if(e)return n(null,"file");t=r&&r.isDirectory()?"dir":"file",n(null,t)}))},symlinkTypeSync:function(e,t){let n;if(t)return t;try{n=En.lstatSync(e)}catch{return"file"}return n&&n.isDirectory()?"dir":"file"}};const hn=re.fromCallback,yn=p.default,Cn=ne,Fn=$e.mkdirs,gn=$e.mkdirsSync,An=pn.symlinkPaths,vn=pn.symlinkPathsSync,Sn=mn.symlinkType,wn=mn.symlinkTypeSync,On=Ge.pathExists,{areIdentical:bn}=et;function _n(e,t,n,r){An(e,t,((u,o)=>{if(u)return r(u);e=o.toDst,Sn(o.toCwd,n,((n,u)=>{if(n)return r(n);const o=yn.dirname(t);On(o,((n,i)=>n?r(n):i?Cn.symlink(e,t,u,r):void Fn(o,(n=>{if(n)return r(n);Cn.symlink(e,t,u,r)}))))}))}))}var Bn={createSymlink:hn((function(e,t,n,r){r="function"==typeof n?n:r,n="function"!=typeof n&&n,Cn.lstat(t,((u,o)=>{!u&&o.isSymbolicLink()?Promise.all([Cn.stat(e),Cn.stat(t)]).then((([u,o])=>{if(bn(u,o))return r(null);_n(e,t,n,r)})):_n(e,t,n,r)}))})),createSymlinkSync:function(e,t,n){let r;try{r=Cn.lstatSync(t)}catch{}if(r&&r.isSymbolicLink()){const n=Cn.statSync(e),r=Cn.statSync(t);if(bn(n,r))return}const u=vn(e,t);e=u.toDst,n=wn(u.toCwd,n);const o=yn.dirname(t);return Cn.existsSync(o)||gn(o),Cn.symlinkSync(e,t,n)}};const{createFile:Pn,createFileSync:kn}=nn,{createLink:xn,createLinkSync:Nn}=ln,{createSymlink:In,createSymlinkSync:Tn}=Bn;var Rn={createFile:Pn,createFileSync:kn,ensureFile:Pn,ensureFileSync:kn,createLink:xn,createLinkSync:Nn,ensureLink:xn,ensureLinkSync:Nn,createSymlink:In,createSymlinkSync:Tn,ensureSymlink:In,ensureSymlinkSync:Tn};var Mn={stringify:function(e,{EOL:t="\n",finalEOL:n=!0,replacer:r=null,spaces:u}={}){const o=n?t:"";return JSON.stringify(e,r,u).replace(/\n/g,t)+o},stripBom:function(e){return Buffer.isBuffer(e)&&(e=e.toString("utf8")),e.replace(/^\uFEFF/,"")}};let Ln;try{Ln=we}catch(e){Ln=D.default}const jn=re,{stringify:$n,stripBom:Hn}=Mn;const Jn=jn.fromPromise((async function(e,t={}){"string"==typeof t&&(t={encoding:t});const n=t.fs||Ln,r=!("throws"in t)||t.throws;let u,o=await jn.fromCallback(n.readFile)(e,t);o=Hn(o);try{u=JSON.parse(o,t?t.reviver:null)}catch(t){if(r)throw t.message=`${e}: ${t.message}`,t;return null}return u}));const Gn=jn.fromPromise((async function(e,t,n={}){const r=n.fs||Ln,u=$n(t,n);await jn.fromCallback(r.writeFile)(e,u,n)}));const Vn={readFile:Jn,readFileSync:function(e,t={}){"string"==typeof t&&(t={encoding:t});const n=t.fs||Ln,r=!("throws"in t)||t.throws;try{let r=n.readFileSync(e,t);return r=Hn(r),JSON.parse(r,t.reviver)}catch(t){if(r)throw t.message=`${e}: ${t.message}`,t;return null}},writeFile:Gn,writeFileSync:function(e,t,n={}){const r=n.fs||Ln,u=$n(t,n);return r.writeFileSync(e,u,n)}};var Un={readJson:Vn.readFile,readJsonSync:Vn.readFileSync,writeJson:Vn.writeFile,writeJsonSync:Vn.writeFileSync};const Wn=re.fromCallback,zn=we,Kn=p.default,qn=$e,Yn=Ge.pathExists;var Xn={outputFile:Wn((function(e,t,n,r){"function"==typeof n&&(r=n,n="utf8");const u=Kn.dirname(e);Yn(u,((o,i)=>o?r(o):i?zn.writeFile(e,t,n,r):void qn.mkdirs(u,(u=>{if(u)return r(u);zn.writeFile(e,t,n,r)}))))})),outputFileSync:function(e,...t){const n=Kn.dirname(e);if(zn.existsSync(n))return zn.writeFileSync(e,...t);qn.mkdirsSync(n),zn.writeFileSync(e,...t)}};const{stringify:Zn}=Mn,{outputFile:Qn}=Xn;var er=async function(e,t,n={}){const r=Zn(t,n);await Qn(e,r,n)};const{stringify:tr}=Mn,{outputFileSync:nr}=Xn;var rr=function(e,t,n){const r=tr(t,n);nr(e,r,n)};const ur=re.fromPromise,or=Un;or.outputJson=ur(er),or.outputJsonSync=rr,or.outputJSON=or.outputJson,or.outputJSONSync=or.outputJsonSync,or.writeJSON=or.writeJson,or.writeJSONSync=or.writeJsonSync,or.readJSON=or.readJson,or.readJSONSync=or.readJsonSync;var ir=or;const sr=we,cr=p.default,ar=Ot.copy,lr=Gt.remove,fr=$e.mkdirp,dr=Ge.pathExists,Dr=et;function pr(e,t,n,r,u){return r?Er(e,t,n,u):n?lr(t,(r=>r?u(r):Er(e,t,n,u))):void dr(t,((r,o)=>r?u(r):o?u(new Error("dest already exists.")):Er(e,t,n,u)))}function Er(e,t,n,r){sr.rename(e,t,(u=>u?"EXDEV"!==u.code?r(u):function(e,t,n,r){const u={overwrite:n,errorOnExist:!0};ar(e,t,u,(t=>t?r(t):lr(e,r)))}(e,t,n,r):r()))}var mr=function(e,t,n,r){"function"==typeof n&&(r=n,n={});const u=n.overwrite||n.clobber||!1;Dr.checkPaths(e,t,"move",n,((n,o)=>{if(n)return r(n);const{srcStat:i,isChangingCase:s=!1}=o;Dr.checkParentPaths(e,i,t,"move",(n=>n?r(n):function(e){const t=cr.dirname(e);return cr.parse(t).root===t}(t)?pr(e,t,u,s,r):void fr(cr.dirname(t),(n=>n?r(n):pr(e,t,u,s,r)))))}))};const hr=we,yr=p.default,Cr=Ot.copySync,Fr=Gt.removeSync,gr=$e.mkdirpSync,Ar=et;function vr(e,t,n){try{hr.renameSync(e,t)}catch(r){if("EXDEV"!==r.code)throw r;return function(e,t,n){const r={overwrite:n,errorOnExist:!0};return Cr(e,t,r),Fr(e)}(e,t,n)}}var Sr=function(e,t,n){const r=(n=n||{}).overwrite||n.clobber||!1,{srcStat:u,isChangingCase:o=!1}=Ar.checkPathsSync(e,t,"move",n);return Ar.checkParentPathsSync(e,u,t,"move"),function(e){const t=yr.dirname(e);return yr.parse(t).root===t}(t)||gr(yr.dirname(t)),function(e,t,n,r){if(r)return vr(e,t,n);if(n)return Fr(t),vr(e,t,n);if(hr.existsSync(t))throw new Error("dest already exists.");return vr(e,t,n)}(e,t,r,o)};var wr,Or,br,_r,Br,Pr={move:(0,re.fromCallback)(mr),moveSync:Sr},kr={...ne,...Ot,...Xt,...Rn,...ir,...$e,...Pr,...Xn,...Ge,...Gt},xr={},Nr={exports:{}},Ir={exports:{}};function Tr(){if(Or)return wr;Or=1;var e=1e3,t=60*e,n=60*t,r=24*n,u=7*r,o=365.25*r;function i(e,t,n,r){var u=t>=1.5*n;return Math.round(e/n)+" "+r+(u?"s":"")}return wr=function(s,c){c=c||{};var a=typeof s;if("string"===a&&s.length>0)return function(i){if((i=String(i)).length>100)return;var s=/^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(i);if(!s)return;var c=parseFloat(s[1]);switch((s[2]||"ms").toLowerCase()){case"years":case"year":case"yrs":case"yr":case"y":return c*o;case"weeks":case"week":case"w":return c*u;case"days":case"day":case"d":return c*r;case"hours":case"hour":case"hrs":case"hr":case"h":return c*n;case"minutes":case"minute":case"mins":case"min":case"m":return c*t;case"seconds":case"second":case"secs":case"sec":case"s":return c*e;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return c;default:return}}(s);if("number"===a&&isFinite(s))return c.long?function(u){var o=Math.abs(u);if(o>=r)return i(u,o,r,"day");if(o>=n)return i(u,o,n,"hour");if(o>=t)return i(u,o,t,"minute");if(o>=e)return i(u,o,e,"second");return u+" ms"}(s):function(u){var o=Math.abs(u);if(o>=r)return Math.round(u/r)+"d";if(o>=n)return Math.round(u/n)+"h";if(o>=t)return Math.round(u/t)+"m";if(o>=e)return Math.round(u/e)+"s";return u+"ms"}(s);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(s))}}function Rr(){if(_r)return br;return _r=1,br=function(e){function t(e){let r,u,o,i=null;function s(...e){if(!s.enabled)return;const n=s,u=Number(new Date),o=u-(r||u);n.diff=o,n.prev=r,n.curr=u,r=u,e[0]=t.coerce(e[0]),"string"!=typeof e[0]&&e.unshift("%O");let i=0;e[0]=e[0].replace(/%([a-zA-Z%])/g,((r,u)=>{if("%%"===r)return"%";i++;const o=t.formatters[u];if("function"==typeof o){const t=e[i];r=o.call(n,t),e.splice(i,1),i--}return r})),t.formatArgs.call(n,e);(n.log||t.log).apply(n,e)}return s.namespace=e,s.useColors=t.useColors(),s.color=t.selectColor(e),s.extend=n,s.destroy=t.destroy,Object.defineProperty(s,"enabled",{enumerable:!0,configurable:!1,get:()=>null!==i?i:(u!==t.namespaces&&(u=t.namespaces,o=t.enabled(e)),o),set:e=>{i=e}}),"function"==typeof t.init&&t.init(s),s}function n(e,n){const r=t(this.namespace+(void 0===n?":":n)+e);return r.log=this.log,r}function r(e){return e.toString().substring(2,e.toString().length-2).replace(/\.\*\?$/,"*")}return t.debug=t,t.default=t,t.coerce=function(e){if(e instanceof Error)return e.stack||e.message;return e},t.disable=function(){const e=[...t.names.map(r),...t.skips.map(r).map((e=>"-"+e))].join(",");return t.enable(""),e},t.enable=function(e){let n;t.save(e),t.namespaces=e,t.names=[],t.skips=[];const r=("string"==typeof e?e:"").split(/[\s,]+/),u=r.length;for(n=0;n{t[n]=e[n]})),t.names=[],t.skips=[],t.formatters={},t.selectColor=function(e){let n=0;for(let t=0;t{const n=e.startsWith("-")?"":1===e.length?"-":"--",r=t.indexOf(n+e),u=t.indexOf("--");return-1!==r&&(-1===u||r{}),"Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."),t.colors=[6,2,3,4,5,1];try{const e=function(){if($r)return jr;$r=1;const e=E.default,t=A.default,n=Vr(),{env:r}=process;let u;function o(e){return 0!==e&&{level:e,hasBasic:!0,has256:e>=2,has16m:e>=3}}function i(t,o){if(0===u)return 0;if(n("color=16m")||n("color=full")||n("color=truecolor"))return 3;if(n("color=256"))return 2;if(t&&!o&&void 0===u)return 0;const i=u||0;if("dumb"===r.TERM)return i;if("win32"===process.platform){const t=e.release().split(".");return Number(t[0])>=10&&Number(t[2])>=10586?Number(t[2])>=14931?3:2:1}if("CI"in r)return["TRAVIS","CIRCLECI","APPVEYOR","GITLAB_CI","GITHUB_ACTIONS","BUILDKITE"].some((e=>e in r))||"codeship"===r.CI_NAME?1:i;if("TEAMCITY_VERSION"in r)return/^(9\.(0*[1-9]\d*)\.|\d{2,}\.)/.test(r.TEAMCITY_VERSION)?1:0;if("truecolor"===r.COLORTERM)return 3;if("TERM_PROGRAM"in r){const e=parseInt((r.TERM_PROGRAM_VERSION||"").split(".")[0],10);switch(r.TERM_PROGRAM){case"iTerm.app":return e>=3?3:2;case"Apple_Terminal":return 2}}return/-256(color)?$/i.test(r.TERM)?2:/^screen|^xterm|^vt100|^vt220|^rxvt|color|ansi|cygwin|linux/i.test(r.TERM)||"COLORTERM"in r?1:i}return n("no-color")||n("no-colors")||n("color=false")||n("color=never")?u=0:(n("color")||n("colors")||n("color=true")||n("color=always"))&&(u=1),"FORCE_COLOR"in r&&(u="true"===r.FORCE_COLOR?1:"false"===r.FORCE_COLOR?0:0===r.FORCE_COLOR.length?1:Math.min(parseInt(r.FORCE_COLOR,10),3)),jr={supportsColor:function(e){return o(i(e,e&&e.isTTY))},stdout:o(i(!0,t.isatty(1))),stderr:o(i(!0,t.isatty(2)))}}();e&&(e.stderr||e).level>=2&&(t.colors=[20,21,26,27,32,33,38,39,40,41,42,43,44,45,56,57,62,63,68,69,74,75,76,77,78,79,80,81,92,93,98,99,112,113,128,129,134,135,148,149,160,161,162,163,164,165,166,167,168,169,170,171,172,173,178,179,184,185,196,197,198,199,200,201,202,203,204,205,206,207,208,209,214,215,220,221])}catch(e){}t.inspectOpts=Object.keys(process.env).filter((e=>/^debug_/i.test(e))).reduce(((e,t)=>{const n=t.substring(6).toLowerCase().replace(/_([a-z])/g,((e,t)=>t.toUpperCase()));let r=process.env[t];return r=!!/^(yes|on|true|enabled)$/i.test(r)||!/^(no|off|false|disabled)$/i.test(r)&&("null"===r?null:Number(r)),e[n]=r,e}),{}),e.exports=Rr()(t);const{formatters:u}=e.exports;u.o=function(e){return this.inspectOpts.colors=this.useColors,r.inspect(e,this.inspectOpts).split("\n").map((e=>e.trim())).join(" ")},u.O=function(e){return this.inspectOpts.colors=this.useColors,r.inspect(e,this.inspectOpts)}}(Gr,Gr.exports)),Gr.exports}Jr=Nr,"undefined"==typeof process||"renderer"===process.type||!0===process.browser||process.__nwjs?Jr.exports=(Br||(Br=1,function(e,t){t.formatArgs=function(t){if(t[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+t[0]+(this.useColors?"%c ":" ")+"+"+e.exports.humanize(this.diff),!this.useColors)return;const n="color: "+this.color;t.splice(1,0,n,"color: inherit");let r=0,u=0;t[0].replace(/%[a-zA-Z%]/g,(e=>{"%%"!==e&&(r++,"%c"===e&&(u=r))})),t.splice(u,0,n)},t.save=function(e){try{e?t.storage.setItem("debug",e):t.storage.removeItem("debug")}catch(e){}},t.load=function(){let e;try{e=t.storage.getItem("debug")}catch(e){}return!e&&"undefined"!=typeof process&&"env"in process&&(e=process.env.DEBUG),e},t.useColors=function(){return!("undefined"==typeof window||!window.process||"renderer"!==window.process.type&&!window.process.__nwjs)||("undefined"==typeof navigator||!navigator.userAgent||!navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/))&&("undefined"!=typeof document&&document.documentElement&&document.documentElement.style&&document.documentElement.style.WebkitAppearance||"undefined"!=typeof window&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||"undefined"!=typeof navigator&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/)&&parseInt(RegExp.$1,10)>=31||"undefined"!=typeof navigator&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/))},t.storage=function(){try{return localStorage}catch(e){}}(),t.destroy=(()=>{let e=!1;return()=>{e||(e=!0,console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."))}})(),t.colors=["#0000CC","#0000FF","#0033CC","#0033FF","#0066CC","#0066FF","#0099CC","#0099FF","#00CC00","#00CC33","#00CC66","#00CC99","#00CCCC","#00CCFF","#3300CC","#3300FF","#3333CC","#3333FF","#3366CC","#3366FF","#3399CC","#3399FF","#33CC00","#33CC33","#33CC66","#33CC99","#33CCCC","#33CCFF","#6600CC","#6600FF","#6633CC","#6633FF","#66CC00","#66CC33","#9900CC","#9900FF","#9933CC","#9933FF","#99CC00","#99CC33","#CC0000","#CC0033","#CC0066","#CC0099","#CC00CC","#CC00FF","#CC3300","#CC3333","#CC3366","#CC3399","#CC33CC","#CC33FF","#CC6600","#CC6633","#CC9900","#CC9933","#CCCC00","#CCCC33","#FF0000","#FF0033","#FF0066","#FF0099","#FF00CC","#FF00FF","#FF3300","#FF3333","#FF3366","#FF3399","#FF33CC","#FF33FF","#FF6600","#FF6633","#FF9900","#FF9933","#FFCC00","#FFCC33"],t.log=console.debug||console.log||(()=>{}),e.exports=Rr()(t);const{formatters:n}=e.exports;n.j=function(e){try{return JSON.stringify(e)}catch(e){return"[UnexpectedJSONParseError]: "+e.message}}}(Ir,Ir.exports)),Ir.exports):Jr.exports=Ur();var Wr=function(e){return(e=e||{}).circles?function(e){var t=[],n=[];return e.proto?function e(u){if("object"!=typeof u||null===u)return u;if(u instanceof Date)return new Date(u);if(Array.isArray(u))return r(u,e);if(u instanceof Map)return new Map(r(Array.from(u),e));if(u instanceof Set)return new Set(r(Array.from(u),e));var o={};for(var i in t.push(u),n.push(o),u){var s=u[i];if("object"!=typeof s||null===s)o[i]=s;else if(s instanceof Date)o[i]=new Date(s);else if(s instanceof Map)o[i]=new Map(r(Array.from(s),e));else if(s instanceof Set)o[i]=new Set(r(Array.from(s),e));else if(ArrayBuffer.isView(s))o[i]=zr(s);else{var c=t.indexOf(s);o[i]=-1!==c?n[c]:e(s)}}return t.pop(),n.pop(),o}:function e(u){if("object"!=typeof u||null===u)return u;if(u instanceof Date)return new Date(u);if(Array.isArray(u))return r(u,e);if(u instanceof Map)return new Map(r(Array.from(u),e));if(u instanceof Set)return new Set(r(Array.from(u),e));var o={};for(var i in t.push(u),n.push(o),u)if(!1!==Object.hasOwnProperty.call(u,i)){var s=u[i];if("object"!=typeof s||null===s)o[i]=s;else if(s instanceof Date)o[i]=new Date(s);else if(s instanceof Map)o[i]=new Map(r(Array.from(s),e));else if(s instanceof Set)o[i]=new Set(r(Array.from(s),e));else if(ArrayBuffer.isView(s))o[i]=zr(s);else{var c=t.indexOf(s);o[i]=-1!==c?n[c]:e(s)}}return t.pop(),n.pop(),o};function r(e,r){for(var u=Object.keys(e),o=new Array(u.length),i=0;i!e,Qr=e=>e&&"object"==typeof e&&!Array.isArray(e),eu=(e,t,n)=>{(Array.isArray(t)?t:[t]).forEach((t=>{if(t)throw new Error(`Problem with log4js configuration: (${Kr.inspect(e,{depth:5})}) - ${n}`)}))};var tu={configure:e=>{qr("New configuration to be validated: ",e),eu(e,Zr(Qr(e)),"must be an object."),qr(`Calling pre-processing listeners (${Yr.length})`),Yr.forEach((t=>t(e))),qr("Configuration pre-processing finished."),qr(`Calling configuration listeners (${Xr.length})`),Xr.forEach((t=>t(e))),qr("Configuration finished.")},addListener:e=>{Xr.push(e),qr(`Added listener, now ${Xr.length} listeners`)},addPreProcessingListener:e=>{Yr.push(e),qr(`Added pre-processing listener, now ${Yr.length} listeners`)},throwExceptionIf:eu,anObject:Qr,anInteger:e=>e&&"number"==typeof e&&Number.isInteger(e),validIdentifier:e=>/^[A-Za-z][A-Za-z0-9_]*$/g.test(e),not:Zr},nu={exports:{}};!function(e){function t(e,t){for(var n=e.toString();n.length-1?s:c,l=n(u.getHours()),f=n(u.getMinutes()),d=n(u.getSeconds()),D=t(u.getMilliseconds(),3),p=function(e){var t=Math.abs(e),n=String(Math.floor(t/60)),r=String(t%60);return n=("0"+n).slice(-2),r=("0"+r).slice(-2),0===e?"Z":(e<0?"+":"-")+n+":"+r}(u.getTimezoneOffset());return r.replace(/dd/g,o).replace(/MM/g,i).replace(/y{1,4}/g,a).replace(/hh/g,l).replace(/mm/g,f).replace(/ss/g,d).replace(/SSS/g,D).replace(/O/g,p)}function u(e,t,n,r){e["set"+(r?"":"UTC")+t](n)}e.exports=r,e.exports.asString=r,e.exports.parse=function(t,n,r){if(!t)throw new Error("pattern must be supplied");return function(t,n,r){var o=t.indexOf("O")<0,i=!1,s=[{pattern:/y{1,4}/,regexp:"\\d{1,4}",fn:function(e,t){u(e,"FullYear",t,o)}},{pattern:/MM/,regexp:"\\d{1,2}",fn:function(e,t){u(e,"Month",t-1,o),e.getMonth()!==t-1&&(i=!0)}},{pattern:/dd/,regexp:"\\d{1,2}",fn:function(e,t){i&&u(e,"Month",e.getMonth()-1,o),u(e,"Date",t,o)}},{pattern:/hh/,regexp:"\\d{1,2}",fn:function(e,t){u(e,"Hours",t,o)}},{pattern:/mm/,regexp:"\\d\\d",fn:function(e,t){u(e,"Minutes",t,o)}},{pattern:/ss/,regexp:"\\d\\d",fn:function(e,t){u(e,"Seconds",t,o)}},{pattern:/SSS/,regexp:"\\d\\d\\d",fn:function(e,t){u(e,"Milliseconds",t,o)}},{pattern:/O/,regexp:"[+-]\\d{1,2}:?\\d{2}?|Z",fn:function(e,t){t="Z"===t?0:t.replace(":","");var n=Math.abs(t),r=(t>0?-1:1)*(n%100+60*Math.floor(n/100));e.setUTCMinutes(e.getUTCMinutes()+r)}}],c=s.reduce((function(e,t){return t.pattern.test(e.regexp)?(t.index=e.regexp.match(t.pattern).index,e.regexp=e.regexp.replace(t.pattern,"("+t.regexp+")")):t.index=-1,e}),{regexp:t,index:[]}),a=s.filter((function(e){return e.index>-1}));a.sort((function(e,t){return e.index-t.index}));var l=new RegExp(c.regexp).exec(n);if(l){var f=r||e.exports.now();return a.forEach((function(e,t){e.fn(f,l[t+1])})),f}throw new Error("String '"+n+"' could not be parsed as '"+t+"'")}(t,n,r)},e.exports.now=function(){return new Date},e.exports.ISO8601_FORMAT="yyyy-MM-ddThh:mm:ss.SSS",e.exports.ISO8601_WITH_TZ_OFFSET_FORMAT="yyyy-MM-ddThh:mm:ss.SSSO",e.exports.DATETIME_FORMAT="dd MM yyyy hh:mm:ss.SSS",e.exports.ABSOLUTETIME_FORMAT="hh:mm:ss.SSS"}(nu);const ru=nu.exports,uu=E.default,ou=F.default,iu=p.default,su={bold:[1,22],italic:[3,23],underline:[4,24],inverse:[7,27],white:[37,39],grey:[90,39],black:[90,39],blue:[34,39],cyan:[36,39],green:[32,39],magenta:[35,39],red:[91,39],yellow:[33,39]};function cu(e){return e?`[${su[e][0]}m`:""}function au(e){return e?`[${su[e][1]}m`:""}function lu(e,t){return n=ou.format("[%s] [%s] %s - ",ru.asString(e.startTime),e.level.toString(),e.categoryName),cu(r=t)+n+au(r);var n,r}function fu(e){return lu(e)+ou.format(...e.data)}function du(e){return lu(e,e.level.colour)+ou.format(...e.data)}function Du(e){return ou.format(...e.data)}function pu(e){return e.data[0]}function Eu(e,t){const n=/%(-?[0-9]+)?(\.?-?[0-9]+)?([[\]cdhmnprzxXyflos%])(\{([^}]+)\})?|([^%]+)/;function r(e){return e&&e.pid?e.pid.toString():process.pid.toString()}e=e||"%r %p %c - %m%n";const u={c:function(e,t){let n=e.categoryName;if(t){const e=parseInt(t,10),r=n.split(".");ee&&(n=r.slice(-e).join(iu.sep))}return n},l:function(e){return e.lineNumber?`${e.lineNumber}`:""},o:function(e){return e.columnNumber?`${e.columnNumber}`:""},s:function(e){return e.callStack||""}};function o(e,t,n){return u[e](t,n)}function i(e,t,n){let r=e;return r=function(e,t){let n;return e?(n=parseInt(e.substr(1),10),n>0?t.slice(0,n):t.slice(n)):t}(t,r),r=function(e,t){let n;if(e)if("-"===e.charAt(0))for(n=parseInt(e.substr(1),10);t.lengthDu,basic:()=>fu,colored:()=>du,coloured:()=>du,pattern:e=>Eu(e&&e.pattern,e&&e.tokens),dummy:()=>pu};var hu={basicLayout:fu,messagePassThroughLayout:Du,patternLayout:Eu,colouredLayout:du,coloredLayout:du,dummyLayout:pu,addLayout(e,t){mu[e]=t},layout:(e,t)=>mu[e]&&mu[e](t)};const yu=tu,Cu=["white","grey","black","blue","cyan","green","magenta","red","yellow"];class Fu{constructor(e,t,n){this.level=e,this.levelStr=t,this.colour=n}toString(){return this.levelStr}static getLevel(e,t){return e?e instanceof Fu?e:(e instanceof Object&&e.levelStr&&(e=e.levelStr),Fu[e.toString().toUpperCase()]||t):t}static addLevels(e){if(e){Object.keys(e).forEach((t=>{const n=t.toUpperCase();Fu[n]=new Fu(e[t].value,n,e[t].colour);const r=Fu.levels.findIndex((e=>e.levelStr===n));r>-1?Fu.levels[r]=Fu[n]:Fu.levels.push(Fu[n])})),Fu.levels.sort(((e,t)=>e.level-t.level))}}isLessThanOrEqualTo(e){return"string"==typeof e&&(e=Fu.getLevel(e)),this.level<=e.level}isGreaterThanOrEqualTo(e){return"string"==typeof e&&(e=Fu.getLevel(e)),this.level>=e.level}isEqualTo(e){return"string"==typeof e&&(e=Fu.getLevel(e)),this.level===e.level}}Fu.levels=[],Fu.addLevels({ALL:{value:Number.MIN_VALUE,colour:"grey"},TRACE:{value:5e3,colour:"blue"},DEBUG:{value:1e4,colour:"cyan"},INFO:{value:2e4,colour:"green"},WARN:{value:3e4,colour:"yellow"},ERROR:{value:4e4,colour:"red"},FATAL:{value:5e4,colour:"magenta"},MARK:{value:9007199254740992,colour:"grey"},OFF:{value:Number.MAX_VALUE,colour:"grey"}}),yu.addListener((e=>{const t=e.levels;if(t){yu.throwExceptionIf(e,yu.not(yu.anObject(t)),"levels must be an object");Object.keys(t).forEach((n=>{yu.throwExceptionIf(e,yu.not(yu.validIdentifier(n)),`level name "${n}" is not a valid identifier (must start with a letter, only contain A-Z,a-z,0-9,_)`),yu.throwExceptionIf(e,yu.not(yu.anObject(t[n])),`level "${n}" must be an object`),yu.throwExceptionIf(e,yu.not(t[n].value),`level "${n}" must have a 'value' property`),yu.throwExceptionIf(e,yu.not(yu.anInteger(t[n].value)),`level "${n}".value must have an integer value`),yu.throwExceptionIf(e,yu.not(t[n].colour),`level "${n}" must have a 'colour' property`),yu.throwExceptionIf(e,yu.not(Cu.indexOf(t[n].colour)>-1),`level "${n}".colour must be one of ${Cu.join(", ")}`)}))}})),yu.addListener((e=>{Fu.addLevels(e.levels)}));var gu=Fu,Au={exports:{}},vu={};/*! (c) 2020 Andrea Giammarchi */
-const{parse:Su,stringify:wu}=JSON,{keys:Ou}=Object,bu=String,_u="string",Bu={},Pu="object",ku=(e,t)=>t,xu=e=>e instanceof bu?bu(e):e,Nu=(e,t)=>typeof t===_u?new bu(t):t,Iu=(e,t,n,r)=>{const u=[];for(let o=Ou(n),{length:i}=o,s=0;s{const r=bu(t.push(n)-1);return e.set(n,r),r},Ru=(e,t)=>{const n=Su(e,Nu).map(xu),r=n[0],u=t||ku,o=typeof r===Pu&&r?Iu(n,new Set,r,u):r;return u.call({"":o},"",o)};vu.parse=Ru;const Mu=(e,t,n)=>{const r=t&&typeof t===Pu?(e,n)=>""===e||-1Su(Mu(e));vu.fromJSON=e=>Ru(wu(e));const Lu=vu,ju=gu;class $u{constructor(e,t,n,r,u){this.startTime=new Date,this.categoryName=e,this.data=n,this.level=t,this.context=Object.assign({},r),this.pid=process.pid,u&&(this.functionName=u.functionName,this.fileName=u.fileName,this.lineNumber=u.lineNumber,this.columnNumber=u.columnNumber,this.callStack=u.callStack)}serialise(){const e=this.data.map((e=>(e&&e.message&&e.stack&&(e=Object.assign({message:e.message,stack:e.stack},e)),e)));return this.data=e,Lu.stringify(this)}static deserialise(e){let t;try{const n=Lu.parse(e);n.data=n.data.map((e=>{if(e&&e.message&&e.stack){const t=new Error(e);Object.keys(e).forEach((n=>{t[n]=e[n]})),e=t}return e})),t=new $u(n.categoryName,ju.getLevel(n.level.levelStr),n.data,n.context),t.startTime=new Date(n.startTime),t.pid=n.pid,t.cluster=n.cluster}catch(n){t=new $u("log4js",ju.ERROR,["Unable to parse log:",e,"because: ",n])}return t}}var Hu=$u;const Ju=Nr.exports("log4js:clustering"),Gu=Hu,Vu=tu;let Uu=!1,Wu=null;try{Wu=require("cluster")}catch(e){Ju("cluster module not present"),Uu=!0}const zu=[];let Ku=!1,qu="NODE_APP_INSTANCE";const Yu=()=>Ku&&"0"===process.env[qu],Xu=()=>Uu||Wu.isMaster||Yu(),Zu=e=>{zu.forEach((t=>t(e)))},Qu=(e,t)=>{if(Ju("cluster message received from worker ",e,": ",t),e.topic&&e.data&&(t=e,e=void 0),t&&t.topic&&"log4js:message"===t.topic){Ju("received message: ",t.data);const e=Gu.deserialise(t.data);Zu(e)}};Uu||Vu.addListener((e=>{zu.length=0,({pm2:Ku,disableClustering:Uu,pm2InstanceVar:qu="NODE_APP_INSTANCE"}=e),Ju(`clustering disabled ? ${Uu}`),Ju(`cluster.isMaster ? ${Wu&&Wu.isMaster}`),Ju(`pm2 enabled ? ${Ku}`),Ju(`pm2InstanceVar = ${qu}`),Ju(`process.env[${qu}] = ${process.env[qu]}`),Ku&&process.removeListener("message",Qu),Wu&&Wu.removeListener&&Wu.removeListener("message",Qu),Uu||e.disableClustering?Ju("Not listening for cluster messages, because clustering disabled."):Yu()?(Ju("listening for PM2 broadcast messages"),process.on("message",Qu)):Wu.isMaster?(Ju("listening for cluster messages"),Wu.on("message",Qu)):Ju("not listening for messages, because we are not a master process")}));var eo={onlyOnMaster:(e,t)=>Xu()?e():t,isMaster:Xu,send:e=>{Xu()?Zu(e):(Ku||(e.cluster={workerId:Wu.worker.id,worker:process.pid}),process.send({topic:"log4js:message",data:e.serialise()}))},onMessage:e=>{zu.push(e)}},to={};function no(e){if("number"==typeof e&&Number.isInteger(e))return e;const t={K:1024,M:1048576,G:1073741824},n=Object.keys(t),r=e.substr(e.length-1).toLocaleUpperCase(),u=e.substring(0,e.length-1).trim();if(n.indexOf(r)<0||!Number.isInteger(Number(u)))throw Error(`maxLogSize: "${e}" is invalid`);return u*t[r]}function ro(e){return function(e,t){const n=Object.assign({},t);return Object.keys(e).forEach((r=>{n[r]&&(n[r]=e[r](t[r]))})),n}({maxLogSize:no},e)}const uo={file:ro,fileSync:ro};to.modifyConfig=e=>uo[e.type]?uo[e.type](e):e;var oo={};const io=console.log.bind(console);oo.configure=function(e,t){let n=t.colouredLayout;return e.layout&&(n=t.layout(e.layout.type,e.layout)),function(e,t){return n=>{io(e(n,t))}}(n,e.timezoneOffset)};var so={};so.configure=function(e,t){let n=t.colouredLayout;return e.layout&&(n=t.layout(e.layout.type,e.layout)),function(e,t){return n=>{process.stdout.write(`${e(n,t)}\n`)}}(n,e.timezoneOffset)};var co={};co.configure=function(e,t){let n=t.colouredLayout;return e.layout&&(n=t.layout(e.layout.type,e.layout)),function(e,t){return n=>{process.stderr.write(`${e(n,t)}\n`)}}(n,e.timezoneOffset)};var ao={};ao.configure=function(e,t,n,r){const u=n(e.appender);return function(e,t,n,r){const u=r.getLevel(e),o=r.getLevel(t,r.FATAL);return e=>{const t=e.level;t.isGreaterThanOrEqualTo(u)&&t.isLessThanOrEqualTo(o)&&n(e)}}(e.level,e.maxLevel,u,r)};var lo={};const fo=Nr.exports("log4js:categoryFilter");lo.configure=function(e,t,n){const r=n(e.appender);return function(e,t){return"string"==typeof e&&(e=[e]),n=>{fo(`Checking ${n.categoryName} against ${e}`),-1===e.indexOf(n.categoryName)&&(fo("Not excluded, sending to appender"),t(n))}}(e.exclude,r)};var Do={};const po=Nr.exports("log4js:noLogFilter");Do.configure=function(e,t,n){const r=n(e.appender);return function(e,t){return n=>{po(`Checking data: ${n.data} against filters: ${e}`),"string"==typeof e&&(e=[e]),e=e.filter((e=>null!=e&&""!==e));const r=new RegExp(e.join("|"),"i");(0===e.length||n.data.findIndex((e=>r.test(e)))<0)&&(po("Not excluded, sending to appender"),t(n))}}(e.exclude,r)};var Eo={},mo={exports:{}},ho={},yo={fromCallback:function(e){return Object.defineProperty((function(){if("function"!=typeof arguments[arguments.length-1])return new Promise(((t,n)=>{arguments[arguments.length]=(e,r)=>{if(e)return n(e);t(r)},arguments.length++,e.apply(this,arguments)}));e.apply(this,arguments)}),"name",{value:e.name})},fromPromise:function(e){return Object.defineProperty((function(){const t=arguments[arguments.length-1];if("function"!=typeof t)return e.apply(this,arguments);e.apply(this,arguments).then((e=>t(null,e)),t)}),"name",{value:e.name})}};!function(e){const t=yo.fromCallback,n=we,r=["access","appendFile","chmod","chown","close","copyFile","fchmod","fchown","fdatasync","fstat","fsync","ftruncate","futimes","lchown","lchmod","link","lstat","mkdir","mkdtemp","open","readFile","readdir","readlink","realpath","rename","rmdir","stat","symlink","truncate","unlink","utimes","writeFile"].filter((e=>"function"==typeof n[e]));Object.keys(n).forEach((t=>{"promises"!==t&&(e[t]=n[t])})),r.forEach((r=>{e[r]=t(n[r])})),e.exists=function(e,t){return"function"==typeof t?n.exists(e,t):new Promise((t=>n.exists(e,t)))},e.read=function(e,t,r,u,o,i){return"function"==typeof i?n.read(e,t,r,u,o,i):new Promise(((i,s)=>{n.read(e,t,r,u,o,((e,t,n)=>{if(e)return s(e);i({bytesRead:t,buffer:n})}))}))},e.write=function(e,t,...r){return"function"==typeof r[r.length-1]?n.write(e,t,...r):new Promise(((u,o)=>{n.write(e,t,...r,((e,t,n)=>{if(e)return o(e);u({bytesWritten:t,buffer:n})}))}))},"function"==typeof n.realpath.native&&(e.realpath.native=t(n.realpath.native))}(ho);const Co=p.default;function Fo(e){return(e=Co.normalize(Co.resolve(e)).split(Co.sep)).length>0?e[0]:null}const go=/[<>:"|?*]/;var Ao=function(e){const t=Fo(e);return e=e.replace(t,""),go.test(e)};const vo=we,So=p.default,wo=Ao,Oo=parseInt("0777",8);var bo=function e(t,n,r,u){if("function"==typeof n?(r=n,n={}):n&&"object"==typeof n||(n={mode:n}),"win32"===process.platform&&wo(t)){const e=new Error(t+" contains invalid WIN32 path characters.");return e.code="EINVAL",r(e)}let o=n.mode;const i=n.fs||vo;void 0===o&&(o=Oo&~process.umask()),u||(u=null),r=r||function(){},t=So.resolve(t),i.mkdir(t,o,(o=>{if(!o)return r(null,u=u||t);if("ENOENT"===o.code){if(So.dirname(t)===t)return r(o);e(So.dirname(t),n,((u,o)=>{u?r(u,o):e(t,n,r,o)}))}else i.stat(t,((e,t)=>{e||!t.isDirectory()?r(o,u):r(null,u)}))}))};const _o=we,Bo=p.default,Po=Ao,ko=parseInt("0777",8);var xo=function e(t,n,r){n&&"object"==typeof n||(n={mode:n});let u=n.mode;const o=n.fs||_o;if("win32"===process.platform&&Po(t)){const e=new Error(t+" contains invalid WIN32 path characters.");throw e.code="EINVAL",e}void 0===u&&(u=ko&~process.umask()),r||(r=null),t=Bo.resolve(t);try{o.mkdirSync(t,u),r=r||t}catch(u){if("ENOENT"===u.code){if(Bo.dirname(t)===t)throw u;r=e(Bo.dirname(t),n,r),e(t,n,r)}else{let e;try{e=o.statSync(t)}catch(e){throw u}if(!e.isDirectory())throw u}}return r};const No=(0,yo.fromCallback)(bo);var Io={mkdirs:No,mkdirsSync:xo,mkdirp:No,mkdirpSync:xo,ensureDir:No,ensureDirSync:xo};const To=we;E.default,p.default;var Ro=function(e,t,n,r){To.open(e,"r+",((e,u)=>{if(e)return r(e);To.futimes(u,t,n,(e=>{To.close(u,(t=>{r&&r(e||t)}))}))}))},Mo=function(e,t,n){const r=To.openSync(e,"r+");return To.futimesSync(r,t,n),To.closeSync(r)};const Lo=we,jo=p.default,$o=10,Ho=5,Jo=0,Go=process.versions.node.split("."),Vo=Number.parseInt(Go[0],10),Uo=Number.parseInt(Go[1],10),Wo=Number.parseInt(Go[2],10);function zo(){if(Vo>$o)return!0;if(Vo===$o){if(Uo>Ho)return!0;if(Uo===Ho&&Wo>=Jo)return!0}return!1}function Ko(e,t){const n=jo.resolve(e).split(jo.sep).filter((e=>e)),r=jo.resolve(t).split(jo.sep).filter((e=>e));return n.reduce(((e,t,n)=>e&&r[n]===t),!0)}function qo(e,t,n){return`Cannot ${n} '${e}' to a subdirectory of itself, '${t}'.`}var Yo,Xo,Zo={checkPaths:function(e,t,n,r){!function(e,t,n){zo()?Lo.stat(e,{bigint:!0},((e,r)=>{if(e)return n(e);Lo.stat(t,{bigint:!0},((e,t)=>e?"ENOENT"===e.code?n(null,{srcStat:r,destStat:null}):n(e):n(null,{srcStat:r,destStat:t})))})):Lo.stat(e,((e,r)=>{if(e)return n(e);Lo.stat(t,((e,t)=>e?"ENOENT"===e.code?n(null,{srcStat:r,destStat:null}):n(e):n(null,{srcStat:r,destStat:t})))}))}(e,t,((u,o)=>{if(u)return r(u);const{srcStat:i,destStat:s}=o;return s&&s.ino&&s.dev&&s.ino===i.ino&&s.dev===i.dev?r(new Error("Source and destination must not be the same.")):i.isDirectory()&&Ko(e,t)?r(new Error(qo(e,t,n))):r(null,{srcStat:i,destStat:s})}))},checkPathsSync:function(e,t,n){const{srcStat:r,destStat:u}=function(e,t){let n,r;n=zo()?Lo.statSync(e,{bigint:!0}):Lo.statSync(e);try{r=zo()?Lo.statSync(t,{bigint:!0}):Lo.statSync(t)}catch(e){if("ENOENT"===e.code)return{srcStat:n,destStat:null};throw e}return{srcStat:n,destStat:r}}(e,t);if(u&&u.ino&&u.dev&&u.ino===r.ino&&u.dev===r.dev)throw new Error("Source and destination must not be the same.");if(r.isDirectory()&&Ko(e,t))throw new Error(qo(e,t,n));return{srcStat:r,destStat:u}},checkParentPaths:function e(t,n,r,u,o){const i=jo.resolve(jo.dirname(t)),s=jo.resolve(jo.dirname(r));if(s===i||s===jo.parse(s).root)return o();zo()?Lo.stat(s,{bigint:!0},((i,c)=>i?"ENOENT"===i.code?o():o(i):c.ino&&c.dev&&c.ino===n.ino&&c.dev===n.dev?o(new Error(qo(t,r,u))):e(t,n,s,u,o))):Lo.stat(s,((i,c)=>i?"ENOENT"===i.code?o():o(i):c.ino&&c.dev&&c.ino===n.ino&&c.dev===n.dev?o(new Error(qo(t,r,u))):e(t,n,s,u,o)))},checkParentPathsSync:function e(t,n,r,u){const o=jo.resolve(jo.dirname(t)),i=jo.resolve(jo.dirname(r));if(i===o||i===jo.parse(i).root)return;let s;try{s=zo()?Lo.statSync(i,{bigint:!0}):Lo.statSync(i)}catch(e){if("ENOENT"===e.code)return;throw e}if(s.ino&&s.dev&&s.ino===n.ino&&s.dev===n.dev)throw new Error(qo(t,r,u));return e(t,n,i,u)},isSrcSubdir:Ko};const Qo=we,ei=p.default,ti=Io.mkdirsSync,ni=Mo,ri=Zo;function ui(e,t,n,r){if(!r.filter||r.filter(t,n))return function(e,t,n,r){const u=r.dereference?Qo.statSync:Qo.lstatSync,o=u(t);if(o.isDirectory())return function(e,t,n,r,u){if(!t)return function(e,t,n,r){return Qo.mkdirSync(n),ii(t,n,r),Qo.chmodSync(n,e.mode)}(e,n,r,u);if(t&&!t.isDirectory())throw new Error(`Cannot overwrite non-directory '${r}' with directory '${n}'.`);return ii(n,r,u)}(o,e,t,n,r);if(o.isFile()||o.isCharacterDevice()||o.isBlockDevice())return function(e,t,n,r,u){return t?function(e,t,n,r){if(r.overwrite)return Qo.unlinkSync(n),oi(e,t,n,r);if(r.errorOnExist)throw new Error(`'${n}' already exists`)}(e,n,r,u):oi(e,n,r,u)}(o,e,t,n,r);if(o.isSymbolicLink())return function(e,t,n,r){let u=Qo.readlinkSync(t);r.dereference&&(u=ei.resolve(process.cwd(),u));if(e){let e;try{e=Qo.readlinkSync(n)}catch(e){if("EINVAL"===e.code||"UNKNOWN"===e.code)return Qo.symlinkSync(u,n);throw e}if(r.dereference&&(e=ei.resolve(process.cwd(),e)),ri.isSrcSubdir(u,e))throw new Error(`Cannot copy '${u}' to a subdirectory of itself, '${e}'.`);if(Qo.statSync(n).isDirectory()&&ri.isSrcSubdir(e,u))throw new Error(`Cannot overwrite '${e}' with '${u}'.`);return function(e,t){return Qo.unlinkSync(t),Qo.symlinkSync(e,t)}(u,n)}return Qo.symlinkSync(u,n)}(e,t,n,r)}(e,t,n,r)}function oi(e,t,n,r){return"function"==typeof Qo.copyFileSync?(Qo.copyFileSync(t,n),Qo.chmodSync(n,e.mode),r.preserveTimestamps?ni(n,e.atime,e.mtime):void 0):function(e,t,n,r){const u=65536,o=(Xo?Yo:(Xo=1,Yo=function(e){if("function"==typeof Buffer.allocUnsafe)try{return Buffer.allocUnsafe(e)}catch(t){return new Buffer(e)}return new Buffer(e)}))(u),i=Qo.openSync(t,"r"),s=Qo.openSync(n,"w",e.mode);let c=0;for(;cfunction(e,t,n,r){const u=ei.join(t,e),o=ei.join(n,e),{destStat:i}=ri.checkPathsSync(u,o,"copy");return ui(i,u,o,r)}(r,e,t,n)))}var si=function(e,t,n){"function"==typeof n&&(n={filter:n}),(n=n||{}).clobber=!("clobber"in n)||!!n.clobber,n.overwrite="overwrite"in n?!!n.overwrite:n.clobber,n.preserveTimestamps&&"ia32"===process.arch&&console.warn("fs-extra: Using the preserveTimestamps option in 32-bit node is not recommended;\n\n see https://github.com/jprichardson/node-fs-extra/issues/269");const{srcStat:r,destStat:u}=ri.checkPathsSync(e,t,"copy");return ri.checkParentPathsSync(e,r,t,"copy"),function(e,t,n,r){if(r.filter&&!r.filter(t,n))return;const u=ei.dirname(n);Qo.existsSync(u)||ti(u);return ui(e,t,n,r)}(u,e,t,n)},ci={copySync:si};const ai=yo.fromPromise,li=ho;var fi={pathExists:ai((function(e){return li.access(e).then((()=>!0)).catch((()=>!1))})),pathExistsSync:li.existsSync};const di=we,Di=p.default,pi=Io.mkdirs,Ei=fi.pathExists,mi=Ro,hi=Zo;function yi(e,t,n,r,u){const o=Di.dirname(n);Ei(o,((i,s)=>i?u(i):s?Fi(e,t,n,r,u):void pi(o,(o=>o?u(o):Fi(e,t,n,r,u)))))}function Ci(e,t,n,r,u,o){Promise.resolve(u.filter(n,r)).then((i=>i?e(t,n,r,u,o):o()),(e=>o(e)))}function Fi(e,t,n,r,u){return r.filter?Ci(gi,e,t,n,r,u):gi(e,t,n,r,u)}function gi(e,t,n,r,u){(r.dereference?di.stat:di.lstat)(t,((o,i)=>o?u(o):i.isDirectory()?function(e,t,n,r,u,o){if(!t)return function(e,t,n,r,u){di.mkdir(n,(o=>{if(o)return u(o);Si(t,n,r,(t=>t?u(t):di.chmod(n,e.mode,u)))}))}(e,n,r,u,o);if(t&&!t.isDirectory())return o(new Error(`Cannot overwrite non-directory '${r}' with directory '${n}'.`));return Si(n,r,u,o)}(i,e,t,n,r,u):i.isFile()||i.isCharacterDevice()||i.isBlockDevice()?function(e,t,n,r,u,o){return t?function(e,t,n,r,u){if(!r.overwrite)return r.errorOnExist?u(new Error(`'${n}' already exists`)):u();di.unlink(n,(o=>o?u(o):Ai(e,t,n,r,u)))}(e,n,r,u,o):Ai(e,n,r,u,o)}(i,e,t,n,r,u):i.isSymbolicLink()?function(e,t,n,r,u){di.readlink(t,((t,o)=>t?u(t):(r.dereference&&(o=Di.resolve(process.cwd(),o)),e?void di.readlink(n,((t,i)=>t?"EINVAL"===t.code||"UNKNOWN"===t.code?di.symlink(o,n,u):u(t):(r.dereference&&(i=Di.resolve(process.cwd(),i)),hi.isSrcSubdir(o,i)?u(new Error(`Cannot copy '${o}' to a subdirectory of itself, '${i}'.`)):e.isDirectory()&&hi.isSrcSubdir(i,o)?u(new Error(`Cannot overwrite '${i}' with '${o}'.`)):function(e,t,n){di.unlink(t,(r=>r?n(r):di.symlink(e,t,n)))}(o,n,u)))):di.symlink(o,n,u))))}(e,t,n,r,u):void 0))}function Ai(e,t,n,r,u){return"function"==typeof di.copyFile?di.copyFile(t,n,(t=>t?u(t):vi(e,n,r,u))):function(e,t,n,r,u){const o=di.createReadStream(t);o.on("error",(e=>u(e))).once("open",(()=>{const t=di.createWriteStream(n,{mode:e.mode});t.on("error",(e=>u(e))).on("open",(()=>o.pipe(t))).once("close",(()=>vi(e,n,r,u)))}))}(e,t,n,r,u)}function vi(e,t,n,r){di.chmod(t,e.mode,(u=>u?r(u):n.preserveTimestamps?mi(t,e.atime,e.mtime,r):r()))}function Si(e,t,n,r){di.readdir(e,((u,o)=>u?r(u):wi(o,e,t,n,r)))}function wi(e,t,n,r,u){const o=e.pop();return o?function(e,t,n,r,u,o){const i=Di.join(n,t),s=Di.join(r,t);hi.checkPaths(i,s,"copy",((t,c)=>{if(t)return o(t);const{destStat:a}=c;Fi(a,i,s,u,(t=>t?o(t):wi(e,n,r,u,o)))}))}(e,o,t,n,r,u):u()}var Oi=function(e,t,n,r){"function"!=typeof n||r?"function"==typeof n&&(n={filter:n}):(r=n,n={}),r=r||function(){},(n=n||{}).clobber=!("clobber"in n)||!!n.clobber,n.overwrite="overwrite"in n?!!n.overwrite:n.clobber,n.preserveTimestamps&&"ia32"===process.arch&&console.warn("fs-extra: Using the preserveTimestamps option in 32-bit node is not recommended;\n\n see https://github.com/jprichardson/node-fs-extra/issues/269"),hi.checkPaths(e,t,"copy",((u,o)=>{if(u)return r(u);const{srcStat:i,destStat:s}=o;hi.checkParentPaths(e,i,t,"copy",(u=>u?r(u):n.filter?Ci(yi,s,e,t,n,r):yi(s,e,t,n,r)))}))};var bi={copy:(0,yo.fromCallback)(Oi)};const _i=we,Bi=p.default,Pi=g.default,ki="win32"===process.platform;function xi(e){["unlink","chmod","stat","lstat","rmdir","readdir"].forEach((t=>{e[t]=e[t]||_i[t],e[t+="Sync"]=e[t]||_i[t]})),e.maxBusyTries=e.maxBusyTries||3}function Ni(e,t,n){let r=0;"function"==typeof t&&(n=t,t={}),Pi(e,"rimraf: missing path"),Pi.strictEqual(typeof e,"string","rimraf: path should be a string"),Pi.strictEqual(typeof n,"function","rimraf: callback function required"),Pi(t,"rimraf: invalid options argument provided"),Pi.strictEqual(typeof t,"object","rimraf: options should be object"),xi(t),Ii(e,t,(function u(o){if(o){if(("EBUSY"===o.code||"ENOTEMPTY"===o.code||"EPERM"===o.code)&&rIi(e,t,u)),100*r)}"ENOENT"===o.code&&(o=null)}n(o)}))}function Ii(e,t,n){Pi(e),Pi(t),Pi("function"==typeof n),t.lstat(e,((r,u)=>r&&"ENOENT"===r.code?n(null):r&&"EPERM"===r.code&&ki?Ti(e,t,r,n):u&&u.isDirectory()?Mi(e,t,r,n):void t.unlink(e,(r=>{if(r){if("ENOENT"===r.code)return n(null);if("EPERM"===r.code)return ki?Ti(e,t,r,n):Mi(e,t,r,n);if("EISDIR"===r.code)return Mi(e,t,r,n)}return n(r)}))))}function Ti(e,t,n,r){Pi(e),Pi(t),Pi("function"==typeof r),n&&Pi(n instanceof Error),t.chmod(e,438,(u=>{u?r("ENOENT"===u.code?null:n):t.stat(e,((u,o)=>{u?r("ENOENT"===u.code?null:n):o.isDirectory()?Mi(e,t,n,r):t.unlink(e,r)}))}))}function Ri(e,t,n){let r;Pi(e),Pi(t),n&&Pi(n instanceof Error);try{t.chmodSync(e,438)}catch(e){if("ENOENT"===e.code)return;throw n}try{r=t.statSync(e)}catch(e){if("ENOENT"===e.code)return;throw n}r.isDirectory()?ji(e,t,n):t.unlinkSync(e)}function Mi(e,t,n,r){Pi(e),Pi(t),n&&Pi(n instanceof Error),Pi("function"==typeof r),t.rmdir(e,(u=>{!u||"ENOTEMPTY"!==u.code&&"EEXIST"!==u.code&&"EPERM"!==u.code?u&&"ENOTDIR"===u.code?r(n):r(u):function(e,t,n){Pi(e),Pi(t),Pi("function"==typeof n),t.readdir(e,((r,u)=>{if(r)return n(r);let o,i=u.length;if(0===i)return t.rmdir(e,n);u.forEach((r=>{Ni(Bi.join(e,r),t,(r=>{if(!o)return r?n(o=r):void(0==--i&&t.rmdir(e,n))}))}))}))}(e,t,r)}))}function Li(e,t){let n;xi(t=t||{}),Pi(e,"rimraf: missing path"),Pi.strictEqual(typeof e,"string","rimraf: path should be a string"),Pi(t,"rimraf: missing options"),Pi.strictEqual(typeof t,"object","rimraf: options should be object");try{n=t.lstatSync(e)}catch(n){if("ENOENT"===n.code)return;"EPERM"===n.code&&ki&&Ri(e,t,n)}try{n&&n.isDirectory()?ji(e,t,null):t.unlinkSync(e)}catch(n){if("ENOENT"===n.code)return;if("EPERM"===n.code)return ki?Ri(e,t,n):ji(e,t,n);if("EISDIR"!==n.code)throw n;ji(e,t,n)}}function ji(e,t,n){Pi(e),Pi(t),n&&Pi(n instanceof Error);try{t.rmdirSync(e)}catch(r){if("ENOTDIR"===r.code)throw n;if("ENOTEMPTY"===r.code||"EEXIST"===r.code||"EPERM"===r.code)!function(e,t){if(Pi(e),Pi(t),t.readdirSync(e).forEach((n=>Li(Bi.join(e,n),t))),!ki){return t.rmdirSync(e,t)}{const n=Date.now();do{try{return t.rmdirSync(e,t)}catch(e){}}while(Date.now()-n<500)}}(e,t);else if("ENOENT"!==r.code)throw r}}var $i=Ni;Ni.sync=Li;const Hi=$i;var Ji={remove:(0,yo.fromCallback)(Hi),removeSync:Hi.sync};const Gi=yo.fromCallback,Vi=we,Ui=p.default,Wi=Io,zi=Ji,Ki=Gi((function(e,t){t=t||function(){},Vi.readdir(e,((n,r)=>{if(n)return Wi.mkdirs(e,t);r=r.map((t=>Ui.join(e,t))),function e(){const n=r.pop();if(!n)return t();zi.remove(n,(n=>{if(n)return t(n);e()}))}()}))}));function qi(e){let t;try{t=Vi.readdirSync(e)}catch(t){return Wi.mkdirsSync(e)}t.forEach((t=>{t=Ui.join(e,t),zi.removeSync(t)}))}var Yi={emptyDirSync:qi,emptydirSync:qi,emptyDir:Ki,emptydir:Ki};const Xi=yo.fromCallback,Zi=p.default,Qi=we,es=Io,ts=fi.pathExists;var ns={createFile:Xi((function(e,t){function n(){Qi.writeFile(e,"",(e=>{if(e)return t(e);t()}))}Qi.stat(e,((r,u)=>{if(!r&&u.isFile())return t();const o=Zi.dirname(e);ts(o,((e,r)=>e?t(e):r?n():void es.mkdirs(o,(e=>{if(e)return t(e);n()}))))}))})),createFileSync:function(e){let t;try{t=Qi.statSync(e)}catch(e){}if(t&&t.isFile())return;const n=Zi.dirname(e);Qi.existsSync(n)||es.mkdirsSync(n),Qi.writeFileSync(e,"")}};const rs=yo.fromCallback,us=p.default,os=we,is=Io,ss=fi.pathExists;var cs={createLink:rs((function(e,t,n){function r(e,t){os.link(e,t,(e=>{if(e)return n(e);n(null)}))}ss(t,((u,o)=>u?n(u):o?n(null):void os.lstat(e,(u=>{if(u)return u.message=u.message.replace("lstat","ensureLink"),n(u);const o=us.dirname(t);ss(o,((u,i)=>u?n(u):i?r(e,t):void is.mkdirs(o,(u=>{if(u)return n(u);r(e,t)}))))}))))})),createLinkSync:function(e,t){if(os.existsSync(t))return;try{os.lstatSync(e)}catch(e){throw e.message=e.message.replace("lstat","ensureLink"),e}const n=us.dirname(t);return os.existsSync(n)||is.mkdirsSync(n),os.linkSync(e,t)}};const as=p.default,ls=we,fs=fi.pathExists;var ds={symlinkPaths:function(e,t,n){if(as.isAbsolute(e))return ls.lstat(e,(t=>t?(t.message=t.message.replace("lstat","ensureSymlink"),n(t)):n(null,{toCwd:e,toDst:e})));{const r=as.dirname(t),u=as.join(r,e);return fs(u,((t,o)=>t?n(t):o?n(null,{toCwd:u,toDst:e}):ls.lstat(e,(t=>t?(t.message=t.message.replace("lstat","ensureSymlink"),n(t)):n(null,{toCwd:e,toDst:as.relative(r,e)})))))}},symlinkPathsSync:function(e,t){let n;if(as.isAbsolute(e)){if(n=ls.existsSync(e),!n)throw new Error("absolute srcpath does not exist");return{toCwd:e,toDst:e}}{const r=as.dirname(t),u=as.join(r,e);if(n=ls.existsSync(u),n)return{toCwd:u,toDst:e};if(n=ls.existsSync(e),!n)throw new Error("relative srcpath does not exist");return{toCwd:e,toDst:as.relative(r,e)}}}};const Ds=we;var ps={symlinkType:function(e,t,n){if(n="function"==typeof t?t:n,t="function"!=typeof t&&t)return n(null,t);Ds.lstat(e,((e,r)=>{if(e)return n(null,"file");t=r&&r.isDirectory()?"dir":"file",n(null,t)}))},symlinkTypeSync:function(e,t){let n;if(t)return t;try{n=Ds.lstatSync(e)}catch(e){return"file"}return n&&n.isDirectory()?"dir":"file"}};const Es=yo.fromCallback,ms=p.default,hs=we,ys=Io.mkdirs,Cs=Io.mkdirsSync,Fs=ds.symlinkPaths,gs=ds.symlinkPathsSync,As=ps.symlinkType,vs=ps.symlinkTypeSync,Ss=fi.pathExists;var ws={createSymlink:Es((function(e,t,n,r){r="function"==typeof n?n:r,n="function"!=typeof n&&n,Ss(t,((u,o)=>u?r(u):o?r(null):void Fs(e,t,((u,o)=>{if(u)return r(u);e=o.toDst,As(o.toCwd,n,((n,u)=>{if(n)return r(n);const o=ms.dirname(t);Ss(o,((n,i)=>n?r(n):i?hs.symlink(e,t,u,r):void ys(o,(n=>{if(n)return r(n);hs.symlink(e,t,u,r)}))))}))}))))})),createSymlinkSync:function(e,t,n){if(hs.existsSync(t))return;const r=gs(e,t);e=r.toDst,n=vs(r.toCwd,n);const u=ms.dirname(t);return hs.existsSync(u)||Cs(u),hs.symlinkSync(e,t,n)}};var Os,bs={createFile:ns.createFile,createFileSync:ns.createFileSync,ensureFile:ns.createFile,ensureFileSync:ns.createFileSync,createLink:cs.createLink,createLinkSync:cs.createLinkSync,ensureLink:cs.createLink,ensureLinkSync:cs.createLinkSync,createSymlink:ws.createSymlink,createSymlinkSync:ws.createSymlinkSync,ensureSymlink:ws.createSymlink,ensureSymlinkSync:ws.createSymlinkSync};try{Os=we}catch(e){Os=D.default}function _s(e,t){var n,r="\n";return"object"==typeof t&&null!==t&&(t.spaces&&(n=t.spaces),t.EOL&&(r=t.EOL)),JSON.stringify(e,t?t.replacer:null,n).replace(/\n/g,r)+r}function Bs(e){return Buffer.isBuffer(e)&&(e=e.toString("utf8")),e=e.replace(/^\uFEFF/,"")}var Ps={readFile:function(e,t,n){null==n&&(n=t,t={}),"string"==typeof t&&(t={encoding:t});var r=(t=t||{}).fs||Os,u=!0;"throws"in t&&(u=t.throws),r.readFile(e,t,(function(r,o){if(r)return n(r);var i;o=Bs(o);try{i=JSON.parse(o,t?t.reviver:null)}catch(t){return u?(t.message=e+": "+t.message,n(t)):n(null,null)}n(null,i)}))},readFileSync:function(e,t){"string"==typeof(t=t||{})&&(t={encoding:t});var n=t.fs||Os,r=!0;"throws"in t&&(r=t.throws);try{var u=n.readFileSync(e,t);return u=Bs(u),JSON.parse(u,t.reviver)}catch(t){if(r)throw t.message=e+": "+t.message,t;return null}},writeFile:function(e,t,n,r){null==r&&(r=n,n={});var u=(n=n||{}).fs||Os,o="";try{o=_s(t,n)}catch(e){return void(r&&r(e,null))}u.writeFile(e,o,n,r)},writeFileSync:function(e,t,n){var r=(n=n||{}).fs||Os,u=_s(t,n);return r.writeFileSync(e,u,n)}},ks=Ps;const xs=yo.fromCallback,Ns=ks;var Is={readJson:xs(Ns.readFile),readJsonSync:Ns.readFileSync,writeJson:xs(Ns.writeFile),writeJsonSync:Ns.writeFileSync};const Ts=p.default,Rs=Io,Ms=fi.pathExists,Ls=Is;var js=function(e,t,n,r){"function"==typeof n&&(r=n,n={});const u=Ts.dirname(e);Ms(u,((o,i)=>o?r(o):i?Ls.writeJson(e,t,n,r):void Rs.mkdirs(u,(u=>{if(u)return r(u);Ls.writeJson(e,t,n,r)}))))};const $s=we,Hs=p.default,Js=Io,Gs=Is;var Vs=function(e,t,n){const r=Hs.dirname(e);$s.existsSync(r)||Js.mkdirsSync(r),Gs.writeJsonSync(e,t,n)};const Us=yo.fromCallback,Ws=Is;Ws.outputJson=Us(js),Ws.outputJsonSync=Vs,Ws.outputJSON=Ws.outputJson,Ws.outputJSONSync=Ws.outputJsonSync,Ws.writeJSON=Ws.writeJson,Ws.writeJSONSync=Ws.writeJsonSync,Ws.readJSON=Ws.readJson,Ws.readJSONSync=Ws.readJsonSync;var zs=Ws;const Ks=we,qs=p.default,Ys=ci.copySync,Xs=Ji.removeSync,Zs=Io.mkdirpSync,Qs=Zo;function ec(e,t,n){try{Ks.renameSync(e,t)}catch(r){if("EXDEV"!==r.code)throw r;return function(e,t,n){const r={overwrite:n,errorOnExist:!0};return Ys(e,t,r),Xs(e)}(e,t,n)}}var tc=function(e,t,n){const r=(n=n||{}).overwrite||n.clobber||!1,{srcStat:u}=Qs.checkPathsSync(e,t,"move");return Qs.checkParentPathsSync(e,u,t,"move"),Zs(qs.dirname(t)),function(e,t,n){if(n)return Xs(t),ec(e,t,n);if(Ks.existsSync(t))throw new Error("dest already exists.");return ec(e,t,n)}(e,t,r)},nc={moveSync:tc};const rc=we,uc=p.default,oc=bi.copy,ic=Ji.remove,sc=Io.mkdirp,cc=fi.pathExists,ac=Zo;function lc(e,t,n,r){rc.rename(e,t,(u=>u?"EXDEV"!==u.code?r(u):function(e,t,n,r){const u={overwrite:n,errorOnExist:!0};oc(e,t,u,(t=>t?r(t):ic(e,r)))}(e,t,n,r):r()))}var fc=function(e,t,n,r){"function"==typeof n&&(r=n,n={});const u=n.overwrite||n.clobber||!1;ac.checkPaths(e,t,"move",((n,o)=>{if(n)return r(n);const{srcStat:i}=o;ac.checkParentPaths(e,i,t,"move",(n=>{if(n)return r(n);sc(uc.dirname(t),(n=>n?r(n):function(e,t,n,r){if(n)return ic(t,(u=>u?r(u):lc(e,t,n,r)));cc(t,((u,o)=>u?r(u):o?r(new Error("dest already exists.")):lc(e,t,n,r)))}(e,t,u,r)))}))}))};var dc={move:(0,yo.fromCallback)(fc)};const Dc=yo.fromCallback,pc=we,Ec=p.default,mc=Io,hc=fi.pathExists;var yc={outputFile:Dc((function(e,t,n,r){"function"==typeof n&&(r=n,n="utf8");const u=Ec.dirname(e);hc(u,((o,i)=>o?r(o):i?pc.writeFile(e,t,n,r):void mc.mkdirs(u,(u=>{if(u)return r(u);pc.writeFile(e,t,n,r)}))))})),outputFileSync:function(e,...t){const n=Ec.dirname(e);if(pc.existsSync(n))return pc.writeFileSync(e,...t);mc.mkdirsSync(n),pc.writeFileSync(e,...t)}};!function(e){e.exports=Object.assign({},ho,ci,bi,Yi,bs,zs,Io,nc,dc,yc,fi,Ji);const t=D.default;Object.getOwnPropertyDescriptor(t,"promises")&&Object.defineProperty(e.exports,"promises",{get:()=>t.promises})}(mo);const Cc=Nr.exports("streamroller:fileNameFormatter"),Fc=p.default;const gc=Nr.exports("streamroller:fileNameParser"),Ac=nu.exports;const vc=Nr.exports("streamroller:moveAndMaybeCompressFile"),Sc=mo.exports,wc=v.default;var Oc=async(e,t,n)=>{if(n=function(e){const t={mode:parseInt("0600",8),compress:!1},n=Object.assign({},t,e);return vc(`_parseOption: moveAndMaybeCompressFile called with option=${JSON.stringify(n)}`),n}(n),e!==t){if(await Sc.pathExists(e))if(vc(`moveAndMaybeCompressFile: moving file from ${e} to ${t} ${n.compress?"with":"without"} compress`),n.compress)await new Promise(((r,u)=>{let o=!1;const i=Sc.createWriteStream(t,{mode:n.mode,flags:"wx"}).on("open",(()=>{o=!0;const t=Sc.createReadStream(e).on("open",(()=>{t.pipe(wc.createGzip()).pipe(i)})).on("error",(t=>{vc(`moveAndMaybeCompressFile: error reading ${e}`,t),i.destroy(t)}))})).on("finish",(()=>{vc(`moveAndMaybeCompressFile: finished compressing ${t}, deleting ${e}`),Sc.unlink(e).then(r).catch((t=>{vc(`moveAndMaybeCompressFile: error deleting ${e}, truncating instead`,t),Sc.truncate(e).then(r).catch((t=>{vc(`moveAndMaybeCompressFile: error truncating ${e}`,t),u(t)}))}))})).on("error",(e=>{o?(vc(`moveAndMaybeCompressFile: error writing ${t}, deleting`,e),Sc.unlink(t).then((()=>{u(e)})).catch((e=>{vc(`moveAndMaybeCompressFile: error deleting ${t}`,e),u(e)}))):(vc(`moveAndMaybeCompressFile: error creating ${t}`,e),u(e))}))})).catch((()=>{}));else{vc(`moveAndMaybeCompressFile: renaming ${e} to ${t}`);try{await Sc.move(e,t,{overwrite:!0})}catch(n){if(vc(`moveAndMaybeCompressFile: error renaming ${e} to ${t}`,n),"ENOENT"!==n.code){vc("moveAndMaybeCompressFile: trying copy+truncate instead");try{await Sc.copy(e,t,{overwrite:!0}),await Sc.truncate(e)}catch(e){vc("moveAndMaybeCompressFile: error copy+truncate",e)}}}}}else vc("moveAndMaybeCompressFile: source and target are the same, not doing anything")};const bc=Nr.exports("streamroller:RollingFileWriteStream"),_c=mo.exports,Bc=p.default,Pc=E.default,kc=()=>new Date,xc=nu.exports,{Writable:Nc}=C.default,Ic=({file:e,keepFileExt:t,needsIndex:n,alwaysIncludeDate:r,compress:u,fileNameSep:o})=>{let i=o||".";const s=Fc.join(e.dir,e.name),c=t=>t+e.ext,a=(e,t,r)=>!n&&r||!t?e:e+i+t,l=(e,t,n)=>(t>0||r)&&n?e+i+n:e,f=(e,t)=>t&&u?e+".gz":e,d=t?[l,a,c,f]:[c,l,a,f];return({date:e,index:t})=>(Cc(`_formatFileName: date=${e}, index=${t}`),d.reduce(((n,r)=>r(n,t,e)),s))},Tc=({file:e,keepFileExt:t,pattern:n,fileNameSep:r})=>{let u=r||".";const o="__NOT_MATCHING__";let i=[(e,t)=>e.endsWith(".gz")?(gc("it is gzipped"),t.isCompressed=!0,e.slice(0,-1*".gz".length)):e,t?t=>t.startsWith(e.name)&&t.endsWith(e.ext)?(gc("it starts and ends with the right things"),t.slice(e.name.length+1,-1*e.ext.length)):o:t=>t.startsWith(e.base)?(gc("it starts with the right things"),t.slice(e.base.length+1)):o,n?(e,t)=>{const r=e.split(u);let o=r[r.length-1];gc("items: ",r,", indexStr: ",o);let i=e;void 0!==o&&o.match(/^\d+$/)?(i=e.slice(0,-1*(o.length+1)),gc(`dateStr is ${i}`),n&&!i&&(i=o,o="0")):o="0";try{const r=Ac.parse(n,i,new Date(0,0));return Ac.asString(n,r)!==i?e:(t.index=parseInt(o,10),t.date=i,t.timestamp=r.getTime(),"")}catch(t){return gc(`Problem parsing ${i} as ${n}, error was: `,t),e}}:(e,t)=>e.match(/^\d+$/)?(gc("it has an index"),t.index=parseInt(e,10),""):e];return e=>{let t={filename:e,index:0,isCompressed:!1};return i.reduce(((e,n)=>n(e,t)),e)?null:t}},Rc=Oc;var Mc=class extends Nc{constructor(e,t){if(bc(`constructor: creating RollingFileWriteStream. path=${e}`),"string"!=typeof e||0===e.length)throw new Error(`Invalid filename: ${e}`);if(e.endsWith(Bc.sep))throw new Error(`Filename is a directory: ${e}`);0===e.indexOf(`~${Bc.sep}`)&&(e=e.replace("~",Pc.homedir())),super(t),this.options=this._parseOption(t),this.fileObject=Bc.parse(e),""===this.fileObject.dir&&(this.fileObject=Bc.parse(Bc.join(process.cwd(),e))),this.fileFormatter=Ic({file:this.fileObject,alwaysIncludeDate:this.options.alwaysIncludePattern,needsIndex:this.options.maxSize 0`)}else delete n.maxSize;if(n.numBackups||0===n.numBackups){if(n.numBackups<0)throw new Error(`options.numBackups (${n.numBackups}) should be >= 0`);if(n.numBackups>=Number.MAX_SAFE_INTEGER)throw new Error(`options.numBackups (${n.numBackups}) should be < Number.MAX_SAFE_INTEGER`);n.numToKeep=n.numBackups+1}else if(n.numToKeep<=0)throw new Error(`options.numToKeep (${n.numToKeep}) should be > 0`);return bc(`_parseOption: creating stream with option=${JSON.stringify(n)}`),n}_final(e){this.currentFileStream.end("",this.options.encoding,e)}_write(e,t,n){this._shouldRoll().then((()=>{bc(`_write: writing chunk. file=${this.currentFileStream.path} state=${JSON.stringify(this.state)} chunk=${e}`),this.currentFileStream.write(e,t,(t=>{this.state.currentSize+=e.length,n(t)}))}))}async _shouldRoll(){(this._dateChanged()||this._tooBig())&&(bc(`_shouldRoll: rolling because dateChanged? ${this._dateChanged()} or tooBig? ${this._tooBig()}`),await this._roll())}_dateChanged(){return this.state.currentDate&&this.state.currentDate!==xc(this.options.pattern,kc())}_tooBig(){return this.state.currentSize>=this.options.maxSize}_roll(){return bc("_roll: closing the current stream"),new Promise(((e,t)=>{this.currentFileStream.end("",this.options.encoding,(()=>{this._moveOldFiles().then(e).catch(t)}))}))}async _moveOldFiles(){const e=await this._getExistingFiles();for(let t=(this.state.currentDate?e.filter((e=>e.date===this.state.currentDate)):e).length;t>=0;t--){bc(`_moveOldFiles: i = ${t}`);const e=this.fileFormatter({date:this.state.currentDate,index:t}),n=this.fileFormatter({date:this.state.currentDate,index:t+1}),r={compress:this.options.compress&&0===t,mode:this.options.mode};await Rc(e,n,r)}this.state.currentSize=0,this.state.currentDate=this.state.currentDate?xc(this.options.pattern,kc()):null,bc(`_moveOldFiles: finished rolling files. state=${JSON.stringify(this.state)}`),this._renewWriteStream(),await new Promise(((e,t)=>{this.currentFileStream.write("","utf8",(()=>{this._clean().then(e).catch(t)}))}))}async _getExistingFiles(){const e=await _c.readdir(this.fileObject.dir).catch((()=>[]));bc(`_getExistingFiles: files=${e}`);const t=e.map((e=>this.fileNameParser(e))).filter((e=>e)),n=e=>(e.timestamp?e.timestamp:kc().getTime())-e.index;return t.sort(((e,t)=>n(e)-n(t))),t}_renewWriteStream(){const e=this.fileFormatter({date:this.state.currentDate,index:0}),t=e=>{try{return _c.mkdirSync(e,{recursive:!0})}catch(n){if("ENOENT"===n.code)return t(Bc.dirname(e)),t(e);if("EEXIST"!==n.code&&"EROFS"!==n.code)throw n;try{if(_c.statSync(e).isDirectory())return e;throw n}catch(e){throw n}}};t(this.fileObject.dir);const n={flags:this.options.flags,encoding:this.options.encoding,mode:this.options.mode};var r,u;_c.appendFileSync(e,"",(r={...n},u="flags",r["flag"]=r[u],delete r[u],r)),this.currentFileStream=_c.createWriteStream(e,n),this.currentFileStream.on("error",(e=>{this.emit("error",e)}))}async _clean(){const e=await this._getExistingFiles();if(bc(`_clean: numToKeep = ${this.options.numToKeep}, existingFiles = ${e.length}`),bc("_clean: existing files are: ",e),this._tooManyFiles(e.length)){const n=e.slice(0,e.length-this.options.numToKeep).map((e=>Bc.format({dir:this.fileObject.dir,base:e.filename})));await(t=n,bc(`deleteFiles: files to delete: ${t}`),Promise.all(t.map((e=>_c.unlink(e).catch((t=>{bc(`deleteFiles: error when unlinking ${e}, ignoring. Error was ${t}`)}))))))}var t}_tooManyFiles(e){return this.options.numToKeep>0&&e>this.options.numToKeep}};const Lc=Mc;var jc=class extends Lc{constructor(e,t,n,r){r||(r={}),t&&(r.maxSize=t),r.numBackups||0===r.numBackups||(n||0===n||(n=1),r.numBackups=n),super(e,r),this.backups=r.numBackups,this.size=this.options.maxSize}get theStream(){return this.currentFileStream}};const $c=Mc;var Hc={RollingFileWriteStream:Mc,RollingFileStream:jc,DateRollingFileStream:class extends $c{constructor(e,t,n){t&&"object"==typeof t&&(n=t,t=null),n||(n={}),t||(t="yyyy-MM-dd"),n.pattern=t,n.numBackups||0===n.numBackups?n.daysToKeep=n.numBackups:(n.daysToKeep||0===n.daysToKeep?process.emitWarning("options.daysToKeep is deprecated due to the confusion it causes when used together with file size rolling. Please use options.numBackups instead.","DeprecationWarning","streamroller-DEP0001"):n.daysToKeep=1,n.numBackups=n.daysToKeep),super(e,n),this.mode=this.options.mode}get theStream(){return this.currentFileStream}}};const Jc=Nr.exports("log4js:file"),Gc=p.default,Vc=Hc,Uc=E.default.EOL;let Wc=!1;const zc=new Set;function Kc(){zc.forEach((e=>{e.sighupHandler()}))}function qc(e,t,n,r){const u=new Vc.RollingFileStream(e,t,n,r);return u.on("error",(t=>{console.error("log4js.fileAppender - Writing to file %s, error happened ",e,t)})),u.on("drain",(()=>{process.emit("log4js:pause",!1)})),u}Eo.configure=function(e,t){let n=t.basicLayout;return e.layout&&(n=t.layout(e.layout.type,e.layout)),e.mode=e.mode||384,function(e,t,n,r,u,o){e=Gc.normalize(e),Jc("Creating file appender (",e,", ",n,", ",r=r||0===r?r:5,", ",u,", ",o,")");let i=qc(e,n,r,u);const s=function(e){if(i.writable){if(!0===u.removeColor){const t=/\x1b[[0-9;]*m/g;e.data=e.data.map((e=>"string"==typeof e?e.replace(t,""):e))}i.write(t(e,o)+Uc,"utf8")||process.emit("log4js:pause",!0)}};return s.reopen=function(){i.end((()=>{i=qc(e,n,r,u)}))},s.sighupHandler=function(){Jc("SIGHUP handler called."),s.reopen()},s.shutdown=function(e){zc.delete(s),0===zc.size&&Wc&&(process.removeListener("SIGHUP",Kc),Wc=!1),i.end("","utf-8",e)},zc.add(s),Wc||(process.on("SIGHUP",Kc),Wc=!0),s}(e.filename,n,e.maxLogSize,e.backups,e,e.timezoneOffset)};var Yc={};const Xc=Hc,Zc=E.default.EOL;function Qc(e,t,n,r,u){r.maxSize=r.maxLogSize;const o=function(e,t,n){const r=new Xc.DateRollingFileStream(e,t,n);return r.on("error",(t=>{console.error("log4js.dateFileAppender - Writing to file %s, error happened ",e,t)})),r.on("drain",(()=>{process.emit("log4js:pause",!1)})),r}(e,t,r),i=function(e){o.writable&&(o.write(n(e,u)+Zc,"utf8")||process.emit("log4js:pause",!0))};return i.shutdown=function(e){o.end("","utf-8",e)},i}Yc.configure=function(e,t){let n=t.basicLayout;return e.layout&&(n=t.layout(e.layout.type,e.layout)),e.alwaysIncludePattern||(e.alwaysIncludePattern=!1),e.mode=e.mode||384,Qc(e.filename,e.pattern,n,e,e.timezoneOffset)};var ea={};const ta=Nr.exports("log4js:fileSync"),na=p.default,ra=D.default,ua=E.default.EOL||"\n";function oa(e,t){if(ra.existsSync(e))return;const n=ra.openSync(e,t.flags,t.mode);ra.closeSync(n)}class ia{constructor(e,t,n,r){ta("In RollingFileStream"),function(){if(!e||!t||t<=0)throw new Error("You must specify a filename and file size")}(),this.filename=e,this.size=t,this.backups=n,this.options=r,this.currentSize=0,this.currentSize=function(e){let t=0;try{t=ra.statSync(e).size}catch(t){oa(e,r)}return t}(this.filename)}shouldRoll(){return ta("should roll with current size %d, and max size %d",this.currentSize,this.size),this.currentSize>=this.size}roll(e){const t=this,n=new RegExp(`^${na.basename(e)}`);function r(e){return n.test(e)}function u(t){return parseInt(t.substring(`${na.basename(e)}.`.length),10)||0}function o(e,t){return u(e)>u(t)?1:u(e) ${e}.${r+1}`),ra.renameSync(na.join(na.dirname(e),n),`${e}.${r+1}`)}}ta("Rolling, rolling, rolling"),ta("Renaming the old files"),ra.readdirSync(na.dirname(e)).filter(r).sort(o).reverse().forEach(i)}write(e,t){const n=this;ta("in write"),this.shouldRoll()&&(this.currentSize=0,this.roll(this.filename)),ta("writing the chunk to the file"),n.currentSize+=e.length,ra.appendFileSync(n.filename,e)}}ea.configure=function(e,t){let n=t.basicLayout;e.layout&&(n=t.layout(e.layout.type,e.layout));const r={flags:e.flags||"a",encoding:e.encoding||"utf8",mode:e.mode||384};return function(e,t,n,r,u,o){ta("fileSync appender created");const i=function(e,t,n){let r;var u;return t?r=new ia(e,t,n,o):(oa(u=e,o),r={write(e){ra.appendFileSync(u,e)}}),r}(e=na.normalize(e),n,r=r||0===r?r:5);return e=>{i.write(t(e,u)+ua)}}(e.filename,n,e.maxLogSize,e.backups,e.timezoneOffset,r)};var sa={};const ca=Nr.exports("log4js:tcp"),aa=S.default;sa.configure=function(e,t){ca(`configure with config = ${e}`);let n=function(e){return e.serialise()};return e.layout&&(n=t.layout(e.layout.type,e.layout)),function(e,t){let n=!1;const r=[];let u,o=3,i="__LOG4JS__";function s(e){ca("Writing log event to socket"),n=u.write(`${t(e)}${i}`,"utf8")}function c(){let e;for(ca("emptying buffer");e=r.shift();)s(e)}function a(e){n?s(e):(ca("buffering log event because it cannot write at the moment"),r.push(e))}return function t(){ca(`appender creating socket to ${e.host||"localhost"}:${e.port||5e3}`),i=`${e.endMsg||"__LOG4JS__"}`,u=aa.createConnection(e.port||5e3,e.host||"localhost"),u.on("connect",(()=>{ca("socket connected"),c(),n=!0})),u.on("drain",(()=>{ca("drain event received, emptying buffer"),n=!0,c()})),u.on("timeout",u.end.bind(u)),u.on("error",(e=>{ca("connection error",e),n=!1,c()})),u.on("close",t)}(),a.shutdown=function(e){ca("shutdown called"),r.length&&o?(ca("buffer has items, waiting 100ms to empty"),o-=1,setTimeout((()=>{a.shutdown(e)}),100)):(u.removeAllListeners("close"),u.end(e))},a}(e,n)};const la=p.default,fa=Nr.exports("log4js:appenders"),da=tu,Da=eo,pa=gu,Ea=hu,ma=to,ha=new Map;ha.set("console",oo),ha.set("stdout",so),ha.set("stderr",co),ha.set("logLevelFilter",ao),ha.set("categoryFilter",lo),ha.set("noLogFilter",Do),ha.set("file",Eo),ha.set("dateFile",Yc),ha.set("fileSync",ea),ha.set("tcp",sa);const ya=new Map,Ca=(e,t)=>{fa("Loading module from ",e);try{return require(e)}catch(n){return void da.throwExceptionIf(t,"MODULE_NOT_FOUND"!==n.code,`appender "${e}" could not be loaded (error was: ${n})`)}},Fa=new Set,ga=(e,t)=>{if(ya.has(e))return ya.get(e);if(!t.appenders[e])return!1;if(Fa.has(e))throw new Error(`Dependency loop detected for appender ${e}.`);Fa.add(e),fa(`Creating appender ${e}`);const n=Aa(e,t);return Fa.delete(e),ya.set(e,n),n},Aa=(e,t)=>{const n=t.appenders[e],r=n.type.configure?n.type:((e,t)=>ha.get(e)||Ca(`./${e}`,t)||Ca(e,t)||require.main&&Ca(la.join(la.dirname(require.main.filename),e),t)||Ca(la.join(process.cwd(),e),t))(n.type,t);return da.throwExceptionIf(t,da.not(r),`appender "${e}" is not valid (type "${n.type}" could not be found)`),r.appender&&fa(`DEPRECATION: Appender ${n.type} exports an appender function.`),r.shutdown&&fa(`DEPRECATION: Appender ${n.type} exports a shutdown function.`),fa(`${e}: clustering.isMaster ? ${Da.isMaster()}`),fa(`${e}: appenderModule is ${F.default.inspect(r)}`),Da.onlyOnMaster((()=>(fa(`calling appenderModule.configure for ${e} / ${n.type}`),r.configure(ma.modifyConfig(n),Ea,(e=>ga(e,t)),pa))),(()=>{}))},va=e=>{ya.clear(),Fa.clear();const t=[];Object.values(e.categories).forEach((e=>{t.push(...e.appenders)})),Object.keys(e.appenders).forEach((n=>{(t.includes(n)||"tcp-server"===e.appenders[n].type)&&ga(n,e)}))},Sa=()=>{va({appenders:{out:{type:"stdout"}},categories:{default:{appenders:["out"],level:"trace"}}})};Sa(),da.addListener((e=>{da.throwExceptionIf(e,da.not(da.anObject(e.appenders)),'must have a property "appenders" of type object.');const t=Object.keys(e.appenders);da.throwExceptionIf(e,da.not(t.length),"must define at least one appender."),t.forEach((t=>{da.throwExceptionIf(e,da.not(e.appenders[t].type),`appender "${t}" is not valid (must be an object with property "type")`)}))})),da.addListener(va),Au.exports=ya,Au.exports.init=Sa;var wa={exports:{}};!function(e){const t=Nr.exports("log4js:categories"),n=tu,r=gu,u=Au.exports,o=new Map;function i(e,t,n){if(!1===t.inherit)return;const r=n.lastIndexOf(".");if(r<0)return;const u=n.substring(0,r);let o=e.categories[u];o||(o={inherit:!0,appenders:[]}),i(e,o,u),!e.categories[u]&&o.appenders&&o.appenders.length&&o.level&&(e.categories[u]=o),t.appenders=t.appenders||[],t.level=t.level||o.level,o.appenders.forEach((e=>{t.appenders.includes(e)||t.appenders.push(e)})),t.parent=o}function s(e){if(!e.categories)return;Object.keys(e.categories).forEach((t=>{const n=e.categories[t];i(e,n,t)}))}n.addPreProcessingListener((e=>s(e))),n.addListener((e=>{n.throwExceptionIf(e,n.not(n.anObject(e.categories)),'must have a property "categories" of type object.');const t=Object.keys(e.categories);n.throwExceptionIf(e,n.not(t.length),"must define at least one category."),t.forEach((t=>{const o=e.categories[t];n.throwExceptionIf(e,[n.not(o.appenders),n.not(o.level)],`category "${t}" is not valid (must be an object with properties "appenders" and "level")`),n.throwExceptionIf(e,n.not(Array.isArray(o.appenders)),`category "${t}" is not valid (appenders must be an array of appender names)`),n.throwExceptionIf(e,n.not(o.appenders.length),`category "${t}" is not valid (appenders must contain at least one appender name)`),Object.prototype.hasOwnProperty.call(o,"enableCallStack")&&n.throwExceptionIf(e,"boolean"!=typeof o.enableCallStack,`category "${t}" is not valid (enableCallStack must be boolean type)`),o.appenders.forEach((r=>{n.throwExceptionIf(e,n.not(u.get(r)),`category "${t}" is not valid (appender "${r}" is not defined)`)})),n.throwExceptionIf(e,n.not(r.getLevel(o.level)),`category "${t}" is not valid (level "${o.level}" not recognised; valid levels are ${r.levels.join(", ")})`)})),n.throwExceptionIf(e,n.not(e.categories.default),'must define a "default" category.')}));const c=e=>{o.clear();Object.keys(e.categories).forEach((n=>{const i=e.categories[n],s=[];i.appenders.forEach((e=>{s.push(u.get(e)),t(`Creating category ${n}`),o.set(n,{appenders:s,level:r.getLevel(i.level),enableCallStack:i.enableCallStack||!1})}))}))},a=()=>{c({categories:{default:{appenders:["out"],level:"OFF"}}})};a(),n.addListener(c);const l=e=>(t(`configForCategory: searching for config for ${e}`),o.has(e)?(t(`configForCategory: ${e} exists in config, returning it`),o.get(e)):e.indexOf(".")>0?(t(`configForCategory: ${e} has hierarchy, searching for parents`),l(e.substring(0,e.lastIndexOf(".")))):(t("configForCategory: returning config for default category"),l("default")));e.exports=o,e.exports=Object.assign(e.exports,{appendersForCategory:e=>l(e).appenders,getLevelForCategory:e=>l(e).level,setLevelForCategory:(e,n)=>{let r=o.get(e);if(t(`setLevelForCategory: found ${r} for ${e}`),!r){const n=l(e);t(`setLevelForCategory: no config found for category, found ${n} for parents of ${e}`),r={appenders:n.appenders}}r.level=n,o.set(e,r)},getEnableCallStackForCategory:e=>!0===l(e).enableCallStack,setEnableCallStackForCategory:(e,t)=>{l(e).enableCallStack=t},init:a})}(wa);const Oa=Nr.exports("log4js:logger"),ba=Hu,_a=gu,Ba=eo,Pa=wa.exports,ka=tu,xa=/at (?:(.+)\s+\()?(?:(.+?):(\d+)(?::(\d+))?|([^)]+))\)?/;function Na(e,t=4){const n=e.stack.split("\n").slice(t),r=xa.exec(n[0]);return r&&6===r.length?{functionName:r[1],fileName:r[2],lineNumber:parseInt(r[3],10),columnNumber:parseInt(r[4],10),callStack:n.join("\n")}:null}class Ia{constructor(e){if(!e)throw new Error("No category provided.");this.category=e,this.context={},this.parseCallStack=Na,Oa(`Logger created (${this.category}, ${this.level})`)}get level(){return _a.getLevel(Pa.getLevelForCategory(this.category),_a.TRACE)}set level(e){Pa.setLevelForCategory(this.category,_a.getLevel(e,this.level))}get useCallStack(){return Pa.getEnableCallStackForCategory(this.category)}set useCallStack(e){Pa.setEnableCallStackForCategory(this.category,!0===e)}log(e,...t){let n=_a.getLevel(e);n||(this._log(_a.WARN,"log4js:logger.log: invalid value for log-level as first parameter given: ",e),n=_a.INFO),this.isLevelEnabled(n)&&this._log(n,t)}isLevelEnabled(e){return this.level.isLessThanOrEqualTo(e)}_log(e,t){Oa(`sending log data (${e}) to appenders`);const n=new ba(this.category,e,t,this.context,this.useCallStack&&this.parseCallStack(new Error));Ba.send(n)}addContext(e,t){this.context[e]=t}removeContext(e){delete this.context[e]}clearContext(){this.context={}}setParseCallStackFunction(e){this.parseCallStack=e}}function Ta(e){const t=_a.getLevel(e),n=t.toString().toLowerCase().replace(/_([a-z])/g,(e=>e[1].toUpperCase())),r=n[0].toUpperCase()+n.slice(1);Ia.prototype[`is${r}Enabled`]=function(){return this.isLevelEnabled(t)},Ia.prototype[n]=function(...e){this.log(t,...e)}}_a.levels.forEach(Ta),ka.addListener((()=>{_a.levels.forEach(Ta)}));var Ra=Ia;const Ma=gu;function La(e){return e.originalUrl||e.url}function ja(e,t){for(let n=0;ne.source?e.source:e));t=new RegExp(n.join("|"))}return t}(t.nolog);return(e,i,s)=>{if(e._logging)return s();if(o&&o.test(e.originalUrl))return s();if(n.isLevelEnabled(r)||"auto"===t.level){const o=new Date,{writeHead:s}=i;e._logging=!0,i.writeHead=(e,t)=>{i.writeHead=s,i.writeHead(e,t),i.__statusCode=e,i.__headers=t||{}},i.on("finish",(()=>{i.responseTime=new Date-o,i.statusCode&&"auto"===t.level&&(r=Ma.INFO,i.statusCode>=300&&(r=Ma.WARN),i.statusCode>=400&&(r=Ma.ERROR)),r=function(e,t,n){let r=t;if(n){const t=n.find((t=>{let n=!1;return n=t.from&&t.to?e>=t.from&&e<=t.to:-1!==t.codes.indexOf(e),n}));t&&(r=Ma.getLevel(t.level,r))}return r}(i.statusCode,r,t.statusRules);const s=function(e,t,n){const r=[];return r.push({token:":url",replacement:La(e)}),r.push({token:":protocol",replacement:e.protocol}),r.push({token:":hostname",replacement:e.hostname}),r.push({token:":method",replacement:e.method}),r.push({token:":status",replacement:t.__statusCode||t.statusCode}),r.push({token:":response-time",replacement:t.responseTime}),r.push({token:":date",replacement:(new Date).toUTCString()}),r.push({token:":referrer",replacement:e.headers.referer||e.headers.referrer||""}),r.push({token:":http-version",replacement:`${e.httpVersionMajor}.${e.httpVersionMinor}`}),r.push({token:":remote-addr",replacement:e.headers["x-forwarded-for"]||e.ip||e._remoteAddress||e.socket&&(e.socket.remoteAddress||e.socket.socket&&e.socket.socket.remoteAddress)}),r.push({token:":user-agent",replacement:e.headers["user-agent"]}),r.push({token:":content-length",replacement:t.getHeader("content-length")||t.__headers&&t.__headers["Content-Length"]||"-"}),r.push({token:/:req\[([^\]]+)]/g,replacement:(t,n)=>e.headers[n.toLowerCase()]}),r.push({token:/:res\[([^\]]+)]/g,replacement:(e,n)=>t.getHeader(n.toLowerCase())||t.__headers&&t.__headers[n]}),(e=>{const t=e.concat();for(let e=0;eja(e,s)));t&&n.log(r,t)}else n.log(r,ja(u,s));t.context&&n.removeContext("res")}))}return s()}},nl=Va;let rl=!1;function ul(e){if(!rl)return;Ua("Received log event ",e);Za.appendersForCategory(e.categoryName).forEach((t=>{t(e)}))}function ol(e){rl&&il();let t=e;return"string"==typeof t&&(t=function(e){Ua(`Loading configuration from ${e}`);try{return JSON.parse(Wa.readFileSync(e,"utf8"))}catch(t){throw new Error(`Problem reading config from file "${e}". Error was ${t.message}`,t)}}(e)),Ua(`Configuration is ${t}`),Ka.configure(za(t)),el.onMessage(ul),rl=!0,sl}function il(e){Ua("Shutdown called. Disabling all log writing."),rl=!1;const t=Array.from(Xa.values());Xa.init(),Za.init();const n=t.reduceRight(((e,t)=>t.shutdown?e+1:e),0);if(0===n)return Ua("No appenders with shutdown functions found."),void 0!==e&&e();let r,u=0;function o(t){r=r||t,u+=1,Ua(`Appender shutdowns complete: ${u} / ${n}`),u>=n&&(Ua("All shutdown functions completed."),e&&e(r))}return Ua(`Found ${n} appenders with shutdown functions.`),t.filter((e=>e.shutdown)).forEach((e=>e.shutdown(o))),null}const sl={getLogger:function(e){return rl||ol(process.env.LOG4JS_CONFIG||{appenders:{out:{type:"stdout"}},categories:{default:{appenders:["out"],level:"OFF"}}}),new Qa(e||"default")},configure:ol,shutdown:il,connectLogger:tl,levels:Ya,addLayout:qa.addLayout,recording:function(){return nl}};var cl=sl,al={};Object.defineProperty(al,"__esModule",{value:!0}),al.levelMap=al.getLevel=al.setCategoriesLevel=al.getConfiguration=al.setConfiguration=void 0;const ll=cl;let fl={appenders:{debug:{type:"stdout",layout:{type:"pattern",pattern:"[%d] > hvigor %p %c %[%m%]"}},info:{type:"stdout",layout:{type:"pattern",pattern:"[%d] > hvigor %[%m%]"}},"no-pattern-info":{type:"stdout",layout:{type:"pattern",pattern:"%m"}},wrong:{type:"stderr",layout:{type:"pattern",pattern:"[%d] > hvigor %[%p: %m%]"}},"just-debug":{type:"logLevelFilter",appender:"debug",level:"debug",maxLevel:"debug"},"just-info":{type:"logLevelFilter",appender:"info",level:"info",maxLevel:"info"},"just-wrong":{type:"logLevelFilter",appender:"wrong",level:"warn",maxLevel:"error"}},categories:{default:{appenders:["just-debug","just-info","just-wrong"],level:"debug"},"no-pattern-info":{appenders:["no-pattern-info"],level:"info"}}};al.setConfiguration=e=>{fl=e};al.getConfiguration=()=>fl;let dl=ll.levels.DEBUG;al.setCategoriesLevel=(e,t)=>{dl=e;const n=fl.categories;for(const r in n)(null==t?void 0:t.includes(r))||Object.prototype.hasOwnProperty.call(n,r)&&(n[r].level=e.levelStr)};al.getLevel=()=>dl,al.levelMap=new Map([["ALL",ll.levels.ALL],["MARK",ll.levels.MARK],["TRACE",ll.levels.TRACE],["DEBUG",ll.levels.DEBUG],["INFO",ll.levels.INFO],["WARN",ll.levels.WARN],["ERROR",ll.levels.ERROR],["FATAL",ll.levels.FATAL],["OFF",ll.levels.OFF]]);var Dl=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),pl=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),El=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)"default"!==n&&Object.prototype.hasOwnProperty.call(e,n)&&Dl(t,e,n);return pl(t,e),t};Object.defineProperty(xr,"__esModule",{value:!0}),xr.evaluateLogLevel=xr.HvigorLogger=void 0;const ml=El(cl),hl=cl,yl=El(F.default),Cl=al;class Fl{constructor(e){ml.configure((0,Cl.getConfiguration)()),this._logger=ml.getLogger(e),this._logger.level=(0,Cl.getLevel)()}static getLogger(e){return new Fl(e)}log(e,...t){this._logger.log(e,...t)}debug(e,...t){this._logger.debug(e,...t)}info(e,...t){this._logger.info(e,...t)}warn(e,...t){void 0!==e&&""!==e&&this._logger.warn(e,...t)}error(e,...t){this._logger.error(e,...t)}_printTaskExecuteInfo(e,t){this.info(`Finished :${e}... after ${t}`)}_printFailedTaskInfo(e){this.error(`Failed :${e}... `)}_printDisabledTaskInfo(e){this.info(`Disabled :${e}... `)}_printUpToDateTaskInfo(e){this.info(`UP-TO-DATE :${e}... `)}errorMessageExit(e,...t){throw new Error(yl.format(e,...t))}errorExit(e,t,...n){t&&this._logger.error(t,n),this._logger.error(e.stack)}setLevel(e,t){(0,Cl.setCategoriesLevel)(e,t),ml.shutdown(),ml.configure((0,Cl.getConfiguration)())}getLevel(){return this._logger.level}configure(e){const t=(0,Cl.getConfiguration)(),n={appenders:{...t.appenders,...e.appenders},categories:{...t.categories,...e.categories}};(0,Cl.setConfiguration)(n),ml.shutdown(),ml.configure(n)}}xr.HvigorLogger=Fl,xr.evaluateLogLevel=function(e,t){t.debug?e.setLevel(hl.levels.DEBUG):t.warn?e.setLevel(hl.levels.WARN):t.error?e.setLevel(hl.levels.ERROR):e.setLevel(hl.levels.INFO)};var gl=w&&w.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(X,"__esModule",{value:!0}),X.parseJsonText=X.parseJsonFile=void 0;const Al=Z,vl=gl(kr),Sl=gl(p.default),wl=gl(E.default),Ol=xr.HvigorLogger.getLogger("parse-json-util");var bl;!function(e){e[e.Char=0]="Char",e[e.EOF=1]="EOF",e[e.Identifier=2]="Identifier"}(bl||(bl={}));let _l,Bl,Pl,kl,xl,Nl,Il="start",Tl=[],Rl=0,Ml=1,Ll=0,jl=!1,$l="default",Hl="'",Jl=1;function Gl(e,t=!1){Bl=String(e),Il="start",Tl=[],Rl=0,Ml=1,Ll=0,kl=void 0,jl=t;do{_l=Vl(),Xl[Il]()}while("eof"!==_l.type);return kl}function Vl(){for($l="default",xl="",Hl="'",Jl=1;;){Nl=Ul();const e=zl[$l]();if(e)return e}}function Ul(){if(Bl[Rl])return String.fromCodePoint(Bl.codePointAt(Rl))}function Wl(){const e=Ul();return"\n"===e?(Ml++,Ll=0):e?Ll+=e.length:Ll++,e&&(Rl+=e.length),e}X.parseJsonFile=function(e,t=!1,n="utf-8"){const r=vl.default.readFileSync(Sl.default.resolve(e),{encoding:n});try{return Gl(r,t)}catch(t){if(t instanceof SyntaxError){const n=t.message.split("at");2===n.length&&Ol.errorMessageExit(`${n[0].trim()}${wl.default.EOL}\t at ${e}:${n[1].trim()}`)}Ol.errorMessageExit(`${e} is not in valid JSON/JSON5 format.`)}},X.parseJsonText=Gl;const zl={default(){switch(Nl){case"/":return Wl(),void($l="comment");case void 0:return Wl(),Kl("eof")}if(!Al.JudgeUtil.isIgnoreChar(Nl)&&!Al.JudgeUtil.isSpaceSeparator(Nl))return zl[Il]();Wl()},start(){$l="value"},beforePropertyName(){switch(Nl){case"$":case"_":return xl=Wl(),void($l="identifierName");case"\\":return Wl(),void($l="identifierNameStartEscape");case"}":return Kl("punctuator",Wl());case'"':case"'":return Hl=Nl,Wl(),void($l="string")}if(Al.JudgeUtil.isIdStartChar(Nl))return xl+=Wl(),void($l="identifierName");throw tf(bl.Char,Wl())},afterPropertyName(){if(":"===Nl)return Kl("punctuator",Wl());throw tf(bl.Char,Wl())},beforePropertyValue(){$l="value"},afterPropertyValue(){switch(Nl){case",":case"}":return Kl("punctuator",Wl())}throw tf(bl.Char,Wl())},beforeArrayValue(){if("]"===Nl)return Kl("punctuator",Wl());$l="value"},afterArrayValue(){switch(Nl){case",":case"]":return Kl("punctuator",Wl())}throw tf(bl.Char,Wl())},end(){throw tf(bl.Char,Wl())},comment(){switch(Nl){case"*":return Wl(),void($l="multiLineComment");case"/":return Wl(),void($l="singleLineComment")}throw tf(bl.Char,Wl())},multiLineComment(){switch(Nl){case"*":return Wl(),void($l="multiLineCommentAsterisk");case void 0:throw tf(bl.Char,Wl())}Wl()},multiLineCommentAsterisk(){switch(Nl){case"*":return void Wl();case"/":return Wl(),void($l="default");case void 0:throw tf(bl.Char,Wl())}Wl(),$l="multiLineComment"},singleLineComment(){switch(Nl){case"\n":case"\r":case"\u2028":case"\u2029":return Wl(),void($l="default");case void 0:return Wl(),Kl("eof")}Wl()},value(){switch(Nl){case"{":case"[":return Kl("punctuator",Wl());case"n":return Wl(),ql("ull"),Kl("null",null);case"t":return Wl(),ql("rue"),Kl("boolean",!0);case"f":return Wl(),ql("alse"),Kl("boolean",!1);case"-":case"+":return"-"===Wl()&&(Jl=-1),void($l="numerical");case".":case"0":case"I":case"N":return void($l="numerical");case'"':case"'":return Hl=Nl,Wl(),xl="",void($l="string")}if(void 0===Nl||!Al.JudgeUtil.isDigitWithoutZero(Nl))throw tf(bl.Char,Wl());$l="numerical"},numerical(){switch(Nl){case".":return xl=Wl(),void($l="decimalPointLeading");case"0":return xl=Wl(),void($l="zero");case"I":return Wl(),ql("nfinity"),Kl("numeric",Jl*(1/0));case"N":return Wl(),ql("aN"),Kl("numeric",NaN)}if(void 0!==Nl&&Al.JudgeUtil.isDigitWithoutZero(Nl))return xl=Wl(),void($l="decimalInteger");throw tf(bl.Char,Wl())},zero(){switch(Nl){case".":case"e":case"E":return void($l="decimal");case"x":case"X":return xl+=Wl(),void($l="hexadecimal")}return Kl("numeric",0)},decimalInteger(){switch(Nl){case".":case"e":case"E":return void($l="decimal")}if(!Al.JudgeUtil.isDigit(Nl))return Kl("numeric",Jl*Number(xl));xl+=Wl()},decimal(){switch(Nl){case".":xl+=Wl(),$l="decimalFraction";break;case"e":case"E":xl+=Wl(),$l="decimalExponent"}},decimalPointLeading(){if(Al.JudgeUtil.isDigit(Nl))return xl+=Wl(),void($l="decimalFraction");throw tf(bl.Char,Wl())},decimalFraction(){switch(Nl){case"e":case"E":return xl+=Wl(),void($l="decimalExponent")}if(!Al.JudgeUtil.isDigit(Nl))return Kl("numeric",Jl*Number(xl));xl+=Wl()},decimalExponent(){switch(Nl){case"+":case"-":return xl+=Wl(),void($l="decimalExponentSign")}if(Al.JudgeUtil.isDigit(Nl))return xl+=Wl(),void($l="decimalExponentInteger");throw tf(bl.Char,Wl())},decimalExponentSign(){if(Al.JudgeUtil.isDigit(Nl))return xl+=Wl(),void($l="decimalExponentInteger");throw tf(bl.Char,Wl())},decimalExponentInteger(){if(!Al.JudgeUtil.isDigit(Nl))return Kl("numeric",Jl*Number(xl));xl+=Wl()},hexadecimal(){if(Al.JudgeUtil.isHexDigit(Nl))return xl+=Wl(),void($l="hexadecimalInteger");throw tf(bl.Char,Wl())},hexadecimalInteger(){if(!Al.JudgeUtil.isHexDigit(Nl))return Kl("numeric",Jl*Number(xl));xl+=Wl()},identifierNameStartEscape(){if("u"!==Nl)throw tf(bl.Char,Wl());Wl();const e=Yl();switch(e){case"$":case"_":break;default:if(!Al.JudgeUtil.isIdStartChar(e))throw tf(bl.Identifier)}xl+=e,$l="identifierName"},identifierName(){switch(Nl){case"$":case"_":case"":case"":return void(xl+=Wl());case"\\":return Wl(),void($l="identifierNameEscape")}if(!Al.JudgeUtil.isIdContinueChar(Nl))return Kl("identifier",xl);xl+=Wl()},identifierNameEscape(){if("u"!==Nl)throw tf(bl.Char,Wl());Wl();const e=Yl();switch(e){case"$":case"_":case"":case"":break;default:if(!Al.JudgeUtil.isIdContinueChar(e))throw tf(bl.Identifier)}xl+=e,$l="identifierName"},string(){switch(Nl){case"\\":return Wl(),void(xl+=function(){const e=Ul(),t=function(){switch(Ul()){case"b":return Wl(),"\b";case"f":return Wl(),"\f";case"n":return Wl(),"\n";case"r":return Wl(),"\r";case"t":return Wl(),"\t";case"v":return Wl(),"\v"}return}();if(t)return t;switch(e){case"0":if(Wl(),Al.JudgeUtil.isDigit(Ul()))throw tf(bl.Char,Wl());return"\0";case"x":return Wl(),function(){let e="",t=Ul();if(!Al.JudgeUtil.isHexDigit(t))throw tf(bl.Char,Wl());if(e+=Wl(),t=Ul(),!Al.JudgeUtil.isHexDigit(t))throw tf(bl.Char,Wl());return e+=Wl(),String.fromCodePoint(parseInt(e,16))}();case"u":return Wl(),Yl();case"\n":case"\u2028":case"\u2029":return Wl(),"";case"\r":return Wl(),"\n"===Ul()&&Wl(),""}if(void 0===e||Al.JudgeUtil.isDigitWithoutZero(e))throw tf(bl.Char,Wl());return Wl()}());case'"':case"'":if(Nl===Hl){const e=Kl("string",xl);return Wl(),e}return void(xl+=Wl());case"\n":case"\r":case void 0:throw tf(bl.Char,Wl());case"\u2028":case"\u2029":!function(e){Ol.warn(`JSON5: '${ef(e)}' in strings is not valid ECMAScript; consider escaping.`)}(Nl)}xl+=Wl()}};function Kl(e,t){return{type:e,value:t,line:Ml,column:Ll}}function ql(e){for(const t of e){if(Ul()!==t)throw tf(bl.Char,Wl());Wl()}}function Yl(){let e="",t=4;for(;t-- >0;){const t=Ul();if(!Al.JudgeUtil.isHexDigit(t))throw tf(bl.Char,Wl());e+=Wl()}return String.fromCodePoint(parseInt(e,16))}const Xl={start(){if("eof"===_l.type)throw tf(bl.EOF);Zl()},beforePropertyName(){switch(_l.type){case"identifier":case"string":return Pl=_l.value,void(Il="afterPropertyName");case"punctuator":return void Ql();case"eof":throw tf(bl.EOF)}},afterPropertyName(){if("eof"===_l.type)throw tf(bl.EOF);Il="beforePropertyValue"},beforePropertyValue(){if("eof"===_l.type)throw tf(bl.EOF);Zl()},afterPropertyValue(){if("eof"===_l.type)throw tf(bl.EOF);switch(_l.value){case",":return void(Il="beforePropertyName");case"}":Ql()}},beforeArrayValue(){if("eof"===_l.type)throw tf(bl.EOF);"punctuator"!==_l.type||"]"!==_l.value?Zl():Ql()},afterArrayValue(){if("eof"===_l.type)throw tf(bl.EOF);switch(_l.value){case",":return void(Il="beforeArrayValue");case"]":Ql()}},end(){}};function Zl(){const e=function(){let e;switch(_l.type){case"punctuator":switch(_l.value){case"{":e={};break;case"[":e=[]}break;case"null":case"boolean":case"numeric":case"string":e=_l.value}return e}();if(jl&&"object"==typeof e&&(e._line=Ml,e._column=Ll),void 0===kl)kl=e;else{const t=Tl[Tl.length-1];Array.isArray(t)?jl&&"object"!=typeof e?t.push({value:e,_line:Ml,_column:Ll}):t.push(e):t[Pl]=jl&&"object"!=typeof e?{value:e,_line:Ml,_column:Ll}:e}!function(e){if(e&&"object"==typeof e)Tl.push(e),Il=Array.isArray(e)?"beforeArrayValue":"beforePropertyName";else{const e=Tl[Tl.length-1];Il=e?Array.isArray(e)?"afterArrayValue":"afterPropertyValue":"end"}}(e)}function Ql(){Tl.pop();const e=Tl[Tl.length-1];Il=e?Array.isArray(e)?"afterArrayValue":"afterPropertyValue":"end"}function ef(e){const t={"'":"\\'",'"':'\\"',"\\":"\\\\","\b":"\\b","\f":"\\f","\n":"\\n","\r":"\\r","\t":"\\t","\v":"\\v","\0":"\\0","\u2028":"\\u2028","\u2029":"\\u2029"};if(t[e])return t[e];if(e<" "){const t=e.charCodeAt(0).toString(16);return`\\x${`00${t}`.substring(t.length)}`}return e}function tf(e,t){let n="";switch(e){case bl.Char:n=void 0===t?`JSON5: invalid end of input at ${Ml}:${Ll}`:`JSON5: invalid character '${ef(t)}' at ${Ml}:${Ll}`;break;case bl.EOF:n=`JSON5: invalid end of input at ${Ml}:${Ll}`;break;case bl.Identifier:Ll-=5,n=`JSON5: invalid identifier character at ${Ml}:${Ll}`}const r=new nf(n);return r.lineNumber=Ml,r.columnNumber=Ll,r}class nf extends SyntaxError{}var rf=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),uf=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),of=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)"default"!==n&&Object.prototype.hasOwnProperty.call(e,n)&&rf(t,e,n);return uf(t,e),t};Object.defineProperty(Y,"__esModule",{value:!0});var sf=Y.cleanWorkSpace=Ff=Y.executeInstallHvigor=yf=Y.isHvigorInstalled=mf=Y.isAllDependenciesInstalled=void 0;const cf=of(D.default),af=of(p.default),lf=b,ff=j,df=$,Df=X;let pf,Ef;var mf=Y.isAllDependenciesInstalled=function(){function e(e){const t=null==e?void 0:e.dependencies;return void 0===t?0:Object.getOwnPropertyNames(t).length}if(pf=gf(),Ef=Af(),e(pf)+1!==e(Ef))return!1;for(const e in null==pf?void 0:pf.dependencies)if(!(0,ff.hasNpmPackInPaths)(e,[lf.HVIGOR_PROJECT_DEPENDENCIES_HOME])||!hf(e,pf,Ef))return!1;return!0};function hf(e,t,n){return void 0!==n.dependencies&&(0,ff.offlinePluginConversion)(lf.HVIGOR_PROJECT_ROOT_DIR,t.dependencies[e])===n.dependencies[e]}var yf=Y.isHvigorInstalled=function(){return pf=gf(),Ef=Af(),(0,ff.hasNpmPackInPaths)(lf.HVIGOR_ENGINE_PACKAGE_NAME,[lf.HVIGOR_PROJECT_DEPENDENCIES_HOME])&&(0,ff.offlinePluginConversion)(lf.HVIGOR_PROJECT_ROOT_DIR,pf.hvigorVersion)===Ef.dependencies[lf.HVIGOR_ENGINE_PACKAGE_NAME]};const Cf={cwd:lf.HVIGOR_PROJECT_DEPENDENCIES_HOME,stdio:["inherit","inherit","inherit"]};var Ff=Y.executeInstallHvigor=function(){(0,df.logInfoPrintConsole)("Hvigor installing...");const e={dependencies:{}};e.dependencies[lf.HVIGOR_ENGINE_PACKAGE_NAME]=(0,ff.offlinePluginConversion)(lf.HVIGOR_PROJECT_ROOT_DIR,pf.hvigorVersion);try{cf.mkdirSync(lf.HVIGOR_PROJECT_DEPENDENCIES_HOME,{recursive:!0});const t=af.resolve(lf.HVIGOR_PROJECT_DEPENDENCIES_HOME,lf.DEFAULT_PACKAGE_JSON);cf.writeFileSync(t,JSON.stringify(e))}catch(e){(0,df.logErrorAndExit)(e)}!function(){const e=["config","set","store-dir",lf.HVIGOR_PNPM_STORE_PATH];(0,ff.executeCommand)(lf.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH,e,Cf)}(),(0,ff.executeCommand)(lf.HVIGOR_WRAPPER_PNPM_SCRIPT_PATH,["install"],Cf)};function gf(){const e=af.resolve(lf.HVIGOR_PROJECT_WRAPPER_HOME,lf.DEFAULT_HVIGOR_CONFIG_JSON_FILE_NAME);return cf.existsSync(e)||(0,df.logErrorAndExit)(`Error: Hvigor config file ${e} does not exist.`),(0,Df.parseJsonFile)(e)}function Af(){return cf.existsSync(lf.HVIGOR_PROJECT_DEPENDENCY_PACKAGE_JSON_PATH)?(0,Df.parseJsonFile)(lf.HVIGOR_PROJECT_DEPENDENCY_PACKAGE_JSON_PATH):{dependencies:{}}}sf=Y.cleanWorkSpace=function(){if((0,df.logInfoPrintConsole)("Hvigor cleaning..."),!cf.existsSync(lf.HVIGOR_PROJECT_DEPENDENCIES_HOME))return;const e=cf.readdirSync(lf.HVIGOR_PROJECT_DEPENDENCIES_HOME);if(e&&0!==e.length){cf.existsSync(lf.HVIGOR_BOOT_JS_FILE_PATH)&&(0,ff.executeCommand)(process.argv[0],[lf.HVIGOR_BOOT_JS_FILE_PATH,"--stop-daemon"],{});try{e.forEach((e=>{cf.rmSync(af.resolve(lf.HVIGOR_PROJECT_DEPENDENCIES_HOME,e),{recursive:!0})}))}catch(e){(0,df.logErrorAndExit)(`The hvigor build tool cannot be installed. Please manually clear the workspace directory and synchronize the project again.\n\n Workspace Path: ${lf.HVIGOR_PROJECT_DEPENDENCIES_HOME}.`)}}};var vf={},Sf=w&&w.__createBinding||(Object.create?function(e,t,n,r){void 0===r&&(r=n);var u=Object.getOwnPropertyDescriptor(t,n);u&&!("get"in u?!t.__esModule:u.writable||u.configurable)||(u={enumerable:!0,get:function(){return t[n]}}),Object.defineProperty(e,r,u)}:function(e,t,n,r){void 0===r&&(r=n),e[r]=t[n]}),wf=w&&w.__setModuleDefault||(Object.create?function(e,t){Object.defineProperty(e,"default",{enumerable:!0,value:t})}:function(e,t){e.default=t}),Of=w&&w.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)"default"!==n&&Object.prototype.hasOwnProperty.call(e,n)&&Sf(t,e,n);return wf(t,e),t};Object.defineProperty(vf,"__esModule",{value:!0});var bf=vf.executeBuild=void 0;const _f=b,Bf=Of(D.default),Pf=Of(p.default),kf=$;bf=vf.executeBuild=function(){const e=Pf.resolve(_f.HVIGOR_PROJECT_DEPENDENCIES_HOME,"node_modules","@ohos","hvigor","bin","hvigor.js");try{const t=Bf.realpathSync(e);require(t)}catch(t){(0,kf.logErrorAndExit)(`Error: ENOENT: no such file ${e},delete ${_f.HVIGOR_PROJECT_DEPENDENCIES_HOME} and retry.`)}},function(){if(O.checkNpmConifg(),O.environmentHandler(),O.isPnpmAvailable()||O.executeInstallPnpm(),yf()&&mf())bf();else{sf();try{Ff()}catch(e){return void sf()}bf()}}();
\ No newline at end of file
diff --git a/storage/storagestatfsjstest/hvigorfile.ts b/storage/storagestatfsjstest/hvigorfile.ts
deleted file mode 100644
index 0b9c10fc3ade5a54609b2d639f808ca7c25a611a..0000000000000000000000000000000000000000
--- a/storage/storagestatfsjstest/hvigorfile.ts
+++ /dev/null
@@ -1,16 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-// Script for compiling build behavior. It is built in the build plug-in and cannot be modified currently.
-export { legacyAppTasks } from '@ohos/hvigor-ohos-plugin';
\ No newline at end of file
diff --git a/storage/storagestatfsjstest/hvigorw b/storage/storagestatfsjstest/hvigorw
deleted file mode 100755
index b4d7760e72934718fc616fcef2806a1c7f04ba34..0000000000000000000000000000000000000000
--- a/storage/storagestatfsjstest/hvigorw
+++ /dev/null
@@ -1,61 +0,0 @@
-# Copyright (c) 2023 Huawei Device Co., Ltd.
-# Licensed under the Apache License, Version 2.0 (the "License");
-# you may not use this file except in compliance with the License.
-# You may obtain a copy of the License at
-#
-# http://www.apache.org/licenses/LICENSE-2.0
-#
-# Unless required by applicable law or agreed to in writing, software
-# distributed under the License is distributed on an "AS IS" BASIS,
-# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-# See the License for the specific language governing permissions and
-# limitations under the License.
-
-#!/bin/bash
-
-# ----------------------------------------------------------------------------
-# Hvigor startup script, version 1.0.0
-#
-# Required ENV vars:
-# ------------------
-# NODE_HOME - location of a Node home dir
-# or
-# Add /usr/local/nodejs/bin to the PATH environment variable
-# ----------------------------------------------------------------------------
-
-HVIGOR_APP_HOME=$(dirname $(readlink -f $0))
-HVIGOR_WRAPPER_SCRIPT=${HVIGOR_APP_HOME}/hvigor/hvigor-wrapper.js
-warn() {
- echo ""
- echo -e "\033[1;33m`date '+[%Y-%m-%d %H:%M:%S]'`$@\033[0m"
-}
-
-error() {
- echo ""
- echo -e "\033[1;31m`date '+[%Y-%m-%d %H:%M:%S]'`$@\033[0m"
-}
-
-fail() {
- error "$@"
- exit 1
-}
-
-# Determine node to start hvigor wrapper script
-if [ -n "${NODE_HOME}" ];then
- EXECUTABLE_NODE="${NODE_HOME}/bin/node"
- if [ ! -x "$EXECUTABLE_NODE" ];then
- fail "ERROR: NODE_HOME is set to an invalid directory,check $NODE_HOME\n\nPlease set NODE_HOME in your environment to the location where your nodejs installed"
- fi
-else
- EXECUTABLE_NODE="node"
- which ${EXECUTABLE_NODE} > /dev/null 2>&1 || fail "ERROR: NODE_HOME is not set and not 'node' command found in your path"
-fi
-
-# Check hvigor wrapper script
-if [ ! -r "$HVIGOR_WRAPPER_SCRIPT" ];then
- fail "ERROR: Couldn't find hvigor/hvigor-wrapper.js in ${HVIGOR_APP_HOME}"
-fi
-
-# start hvigor-wrapper script
-exec "${EXECUTABLE_NODE}" \
- "${HVIGOR_WRAPPER_SCRIPT}" "$@"
diff --git a/storage/storagestatfsjstest/hvigorw.bat b/storage/storagestatfsjstest/hvigorw.bat
deleted file mode 100644
index a9cc1302dc821de7f9f82c3327673a730945ec7d..0000000000000000000000000000000000000000
--- a/storage/storagestatfsjstest/hvigorw.bat
+++ /dev/null
@@ -1,70 +0,0 @@
-@rem Copyright (C) 2023 Huawei Device Co., Ltd.
-@rem Licensed under the Apache License, Version 2.0 (the "License");
-@rem you may not use this file except in compliance with the License.
-@rem You may obtain a copy of the License at
-@rem
-@rem http://www.apache.org/licenses/LICENSE-2.0
-@rem
-@rem Unless required by applicable law or agreed to in writing, software
-@rem distributed under the License is distributed on an "AS IS" BASIS,
-@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-@rem See the License for the specific language governing permissions and
-@rem limitations under the License.
-
-@if "%DEBUG%" == "" @echo off
-@rem ##########################################################################
-@rem
-@rem Hvigor startup script for Windows
-@rem
-@rem ##########################################################################
-
-@rem Set local scope for the variables with windows NT shell
-if "%OS%"=="Windows_NT" setlocal
-
-set DIRNAME=%~dp0
-if "%DIRNAME%" == "" set DIRNAME=.
-set APP_BASE_NAME=%~n0
-set APP_HOME=%DIRNAME%
-
-@rem Resolve any "." and ".." in APP_HOME to make it shorter.
-for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi
-
-set WRAPPER_MODULE_PATH=%APP_HOME%\hvigor\hvigor-wrapper.js
-set NODE_EXE=node.exe
-
-goto start
-
-:start
-@rem Find node.exe
-if defined NODE_HOME goto findNodeFromNodeHome
-
-%NODE_EXE% --version >NUL 2>&1
-if "%ERRORLEVEL%" == "0" goto execute
-
-echo.
-echo ERROR: NODE_HOME is not set and no 'node' command could be found in your PATH.
-echo.
-echo Please set the NODE_HOME variable in your environment to match the
-echo location of your NodeJs installation.
-
-goto fail
-
-:findNodeFromNodeHome
-set NODE_HOME=%NODE_HOME:"=%
-set NODE_EXE_PATH=%NODE_HOME%/%NODE_EXE%
-
-if exist "%NODE_EXE_PATH%" goto execute
-echo.
-echo ERROR: NODE_HOME is not set and no 'node' command could be found in your PATH.
-echo.
-echo Please set the NODE_HOME variable in your environment to match the
-echo location of your NodeJs installation.
-
-goto fail
-
-:execute
-@rem Execute hvigor
-"%NODE_EXE%" %WRAPPER_MODULE_PATH% %*
-
-:fail
-exit /b 1
diff --git a/storage/storagestatfsjstest/oh-package.json5 b/storage/storagestatfsjstest/oh-package.json5
deleted file mode 100644
index 1a98aac1810691829d1f9908395de4863cb0623d..0000000000000000000000000000000000000000
--- a/storage/storagestatfsjstest/oh-package.json5
+++ /dev/null
@@ -1,26 +0,0 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-{
- "license": "",
- "devDependencies": {
- "@ohos/hypium": "1.0.6"
- },
- "author": "",
- "name": "myapplication454434",
- "description": "Please describe the basic information.",
- "main": "",
- "version": "1.0.0",
- "dependencies": {}
-}
diff --git a/storage/storagestatfsjstest/src/main/config.json b/storage/storagestatfsjstest/src/main/config.json
new file mode 100644
index 0000000000000000000000000000000000000000..50311ba4deff8e026b1f47e97ae4365afc51cda6
--- /dev/null
+++ b/storage/storagestatfsjstest/src/main/config.json
@@ -0,0 +1,96 @@
+{
+ "app": {
+ "bundleName": "ohos.acts.storage.statfs",
+ "vendor": "example",
+ "version": {
+ "code": 1000000,
+ "name": "1.0.0"
+ },
+ "apiVersion": {
+ "compatible": 4,
+ "target": 5
+ }
+ },
+ "deviceConfig": {},
+ "module": {
+ "package": "ohos.acts.storage.statfs",
+ "name": ".entry",
+ "deviceType": [
+ "tablet",
+ "default",
+ "phone"
+ ],
+ "distro": {
+ "deliveryWithInstall": true,
+ "moduleName": "entry",
+ "moduleType": "entry",
+ "installationFree": true
+ },
+ "abilities": [
+ {
+ "skills": [
+ {
+ "entities": [
+ "entity.system.home"
+ ],
+ "actions": [
+ "action.system.home"
+ ]
+ }
+ ],
+ "orientation": "unspecified",
+ "formsEnabled": false,
+ "name": ".MainAbility",
+ "srcLanguage": "js",
+ "srcPath": "MainAbility",
+ "icon": "$media:icon",
+ "description": "$string:MainAbility_desc",
+ "label": "$string:MainAbility_label",
+ "type": "page",
+ "visible": true,
+ "launchType": "standard"
+ },
+ {
+ "orientation": "unspecified",
+ "formsEnabled": false,
+ "name": ".TestAbility",
+ "srcLanguage": "js",
+ "srcPath": "TestAbility",
+ "icon": "$media:icon",
+ "description": "$string:TestAbility_desc",
+ "label": "$string:TestAbility_label",
+ "type": "page",
+ "visible": true,
+ "launchType": "standard"
+ }
+ ],
+ "js": [
+ {
+ "pages": [
+ "pages/index/index"
+ ],
+ "name": "default",
+ "window": {
+ "designWidth": 720,
+ "autoDesignWidth": false
+ }
+ },
+ {
+ "pages": [
+ "pages/index/index"
+ ],
+ "name": ".TestAbility",
+ "window": {
+ "designWidth": 720,
+ "autoDesignWidth": false
+ }
+ }
+ ],
+ "testRunner": {
+ "name": "OpenHarmonyTestRunner",
+ "srcPath": "TestRunner"
+ },
+ "mainAbility": ".MainAbility",
+ "srcPath": ""
+ }
+}
\ No newline at end of file
diff --git a/storage/storagestatfsjstest/src/main/js/MainAbility/app.js b/storage/storagestatfsjstest/src/main/js/MainAbility/app.js
new file mode 100644
index 0000000000000000000000000000000000000000..37aa79e4519ba957fcb84d27a32c566c86ae7844
--- /dev/null
+++ b/storage/storagestatfsjstest/src/main/js/MainAbility/app.js
@@ -0,0 +1,23 @@
+/*
+ * Copyright (C) 2021 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+export default {
+ onCreate() {
+ console.info('ohos.acts.storage.statfs onCreate');
+ },
+ onDestroy() {
+ console.info('ohos.acts.storage.statfs onDestroy');
+ }
+};
diff --git a/storage/storagestatfsjstest/src/main/js/MainAbility/i18n/en-US.json b/storage/storagestatfsjstest/src/main/js/MainAbility/i18n/en-US.json
new file mode 100644
index 0000000000000000000000000000000000000000..ead52ed2e09ec82aaf7aa9f4e714ed39ea88308e
--- /dev/null
+++ b/storage/storagestatfsjstest/src/main/js/MainAbility/i18n/en-US.json
@@ -0,0 +1,6 @@
+{
+ "strings": {
+ "hello": "Hello",
+ "world": "Test"
+ }
+}
\ No newline at end of file
diff --git a/storage/storagestatfsjstest/src/main/js/MainAbility/i18n/zh-CN.json b/storage/storagestatfsjstest/src/main/js/MainAbility/i18n/zh-CN.json
new file mode 100644
index 0000000000000000000000000000000000000000..3f48f2585b24a8fe4a745e8ee2972a9e991a7803
--- /dev/null
+++ b/storage/storagestatfsjstest/src/main/js/MainAbility/i18n/zh-CN.json
@@ -0,0 +1,6 @@
+{
+ "strings": {
+ "hello": "您好",
+ "world": "测试"
+ }
+}
\ No newline at end of file
diff --git a/storage/storagestatfsjstest/src/main/js/MainAbility/pages/index/index.css b/storage/storagestatfsjstest/src/main/js/MainAbility/pages/index/index.css
new file mode 100644
index 0000000000000000000000000000000000000000..6fda792753f2e15f22b529c7b90a82185b2770bf
--- /dev/null
+++ b/storage/storagestatfsjstest/src/main/js/MainAbility/pages/index/index.css
@@ -0,0 +1,9 @@
+.container {
+ flex-direction: column;
+ justify-content: center;
+ align-items: center;
+}
+
+.title {
+ font-size: 100px;
+}
diff --git a/storage/storagestatfsjstest/src/main/js/MainAbility/pages/index/index.hml b/storage/storagestatfsjstest/src/main/js/MainAbility/pages/index/index.hml
new file mode 100644
index 0000000000000000000000000000000000000000..f64b040a5ae394dbaa5e185e1ecd4f4556b92184
--- /dev/null
+++ b/storage/storagestatfsjstest/src/main/js/MainAbility/pages/index/index.hml
@@ -0,0 +1,5 @@
+
+
+ {{ $t('strings.hello') }} {{ title }}
+
+
diff --git a/storage/storagestatfsjstest/src/main/js/MainAbility/pages/index/index.js b/storage/storagestatfsjstest/src/main/js/MainAbility/pages/index/index.js
new file mode 100644
index 0000000000000000000000000000000000000000..5f9fe94e4bc5dc38ed24399a7bc18167d42310fc
--- /dev/null
+++ b/storage/storagestatfsjstest/src/main/js/MainAbility/pages/index/index.js
@@ -0,0 +1,34 @@
+/*
+ * Copyright (C) 2021 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import app from '@system.app'
+
+
+const injectRef = Object.getPrototypeOf(global) || global
+injectRef.regeneratorRuntime = require('@babel/runtime/regenerator')
+
+export default {
+ data: {
+ title: ''
+ },
+ onInit() {
+ this.title = this.$t('strings.world');
+ },
+ onShow() {
+ console.info('onShow finish')
+ },
+ onReady() {
+ },
+}
\ No newline at end of file
diff --git a/storage/storagestatfsjstest/src/main/js/TestAbility/app.js b/storage/storagestatfsjstest/src/main/js/TestAbility/app.js
new file mode 100644
index 0000000000000000000000000000000000000000..cdc31f3dcf031e2f6a7665d9653e53bb649e21c5
--- /dev/null
+++ b/storage/storagestatfsjstest/src/main/js/TestAbility/app.js
@@ -0,0 +1,31 @@
+/*
+ * Copyright (c) 2022 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry'
+import { Hypium } from '@ohos/hypium'
+import testsuite from '../test/List.test'
+
+export default {
+ onCreate() {
+ console.info('TestApplication onCreate')
+ var abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator()
+ var abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments()
+ console.info('start run testcase!!!')
+ Hypium.hypiumTest(abilityDelegator, abilityDelegatorArguments, testsuite)
+ },
+ onDestroy() {
+ console.info("TestApplication onDestroy");
+ }
+};
diff --git a/storage/storagestatfsjstest/src/main/js/TestAbility/i18n/en-US.json b/storage/storagestatfsjstest/src/main/js/TestAbility/i18n/en-US.json
new file mode 100644
index 0000000000000000000000000000000000000000..3cb24b374b1d919ca8eac0638f361692b603a900
--- /dev/null
+++ b/storage/storagestatfsjstest/src/main/js/TestAbility/i18n/en-US.json
@@ -0,0 +1,8 @@
+{
+ "strings": {
+ "hello": "Hello",
+ "world": "World"
+ },
+ "Files": {
+ }
+}
\ No newline at end of file
diff --git a/storage/storagestatfsjstest/src/main/js/TestAbility/i18n/zh-CN.json b/storage/storagestatfsjstest/src/main/js/TestAbility/i18n/zh-CN.json
new file mode 100644
index 0000000000000000000000000000000000000000..c804e32c0c3103929baca5617cdac70be11fdba1
--- /dev/null
+++ b/storage/storagestatfsjstest/src/main/js/TestAbility/i18n/zh-CN.json
@@ -0,0 +1,8 @@
+{
+ "strings": {
+ "hello": "您好",
+ "world": "世界"
+ },
+ "Files": {
+ }
+}
\ No newline at end of file
diff --git a/storage/storagefileurijstest/entry/src/ohosTest/js/TestAbility/pages/index/index.css b/storage/storagestatfsjstest/src/main/js/TestAbility/pages/index/index.css
similarity index 100%
rename from storage/storagefileurijstest/entry/src/ohosTest/js/TestAbility/pages/index/index.css
rename to storage/storagestatfsjstest/src/main/js/TestAbility/pages/index/index.css
diff --git a/storage/storagestatfsjstest/src/main/js/TestAbility/pages/index/index.hml b/storage/storagestatfsjstest/src/main/js/TestAbility/pages/index/index.hml
new file mode 100644
index 0000000000000000000000000000000000000000..f629c71a9be857db6cdf94149652a191b9b272ea
--- /dev/null
+++ b/storage/storagestatfsjstest/src/main/js/TestAbility/pages/index/index.hml
@@ -0,0 +1,5 @@
+
+
+ {{ $t('strings.hello') }} {{ title }}
+
+
diff --git a/storage/storagestatfsjstest/src/main/js/TestAbility/pages/index/index.js b/storage/storagestatfsjstest/src/main/js/TestAbility/pages/index/index.js
new file mode 100644
index 0000000000000000000000000000000000000000..88b083a7f6b979019d6a2c5ad20b19c5fd43286b
--- /dev/null
+++ b/storage/storagestatfsjstest/src/main/js/TestAbility/pages/index/index.js
@@ -0,0 +1,26 @@
+/*
+ * Copyright (c) 2022 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+export default {
+ data: {
+ title: ""
+ },
+ onInit() {
+ this.title = this.$t('strings.world');
+ }
+}
+
+
+
diff --git a/storage/storagestatfsjstest/src/main/js/TestRunner/OpenHarmonyTestRunner.js b/storage/storagestatfsjstest/src/main/js/TestRunner/OpenHarmonyTestRunner.js
new file mode 100644
index 0000000000000000000000000000000000000000..c5fa8620ca77d381f20b65a903b833e6e3378c97
--- /dev/null
+++ b/storage/storagestatfsjstest/src/main/js/TestRunner/OpenHarmonyTestRunner.js
@@ -0,0 +1,59 @@
+/*
+ * Copyright (c) 2022 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import AbilityDelegatorRegistry from '@ohos.application.abilityDelegatorRegistry'
+
+function translateParamsToString(parameters) {
+ const keySet = new Set([
+ '-s class', '-s notClass', '-s suite', '-s itName',
+ '-s level', '-s testType', '-s size', '-s timeout',
+ '-s package', '-s dryRun'
+ ])
+ let targetParams = '';
+ for (const key in parameters) {
+ if (keySet.has(key)) {
+ targetParams += ' ' + key + ' ' + parameters[key]
+ }
+ }
+ return targetParams.trim()
+}
+
+ export default {
+ onPrepare() {
+ console.info('OpenHarmonyTestRunner OnPrepare')
+ },
+ onRun() {
+ console.log('OpenHarmonyTestRunner onRun run')
+ var abilityDelegatorArguments = AbilityDelegatorRegistry.getArguments()
+ var abilityDelegator = AbilityDelegatorRegistry.getAbilityDelegator()
+
+ var testAbilityName = abilityDelegatorArguments.parameters['-p'] + '.TestAbility'
+
+ var cmd = 'aa start -d 0 -a ' + testAbilityName + ' -b ' + abilityDelegatorArguments.bundleName
+ cmd += ' ' + translateParamsToString(abilityDelegatorArguments.parameters)
+ var debug = abilityDelegatorArguments.parameters["-D"]
+ console.info('debug value : '+debug)
+ if (debug == 'true')
+ {
+ cmd += ' -D'
+ }
+ console.info('cmd : '+cmd)
+ abilityDelegator.executeShellCommand(cmd, (err, data) => {
+ console.info('executeShellCommand : err : ' + JSON.stringify(err));
+ console.info('executeShellCommand : data : ' + data.stdResult);
+ console.info('executeShellCommand : data : ' + data.exitCode);
+ })
+ }
+};
diff --git a/storage/storagestatfsjstest/entry/src/ohosTest/js/test/Common.js b/storage/storagestatfsjstest/src/main/js/test/Common.js
similarity index 79%
rename from storage/storagestatfsjstest/entry/src/ohosTest/js/test/Common.js
rename to storage/storagestatfsjstest/src/main/js/test/Common.js
index b5d4c17f634bc74d1d764dc67cc1891cf6e7f015..20c2c416169da3e351d6553ee154a915dc233a1f 100644
--- a/storage/storagestatfsjstest/entry/src/ohosTest/js/test/Common.js
+++ b/storage/storagestatfsjstest/src/main/js/test/Common.js
@@ -1,13 +1,13 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
+/*
+ * Copyright (C) 2021 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
+ * distributed under the License is distributed on an 'AS IS' BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
diff --git a/storage/storagestatfsjstest/entry/src/ohosTest/js/test/List.test.js b/storage/storagestatfsjstest/src/main/js/test/List.test.js
similarity index 90%
rename from storage/storagestatfsjstest/entry/src/ohosTest/js/test/List.test.js
rename to storage/storagestatfsjstest/src/main/js/test/List.test.js
index 98dc2825282ae284f705368b2f4cb2f4cc9a228c..52a7c87529423b5e4103ed61ef6333338b1dbb8e 100644
--- a/storage/storagestatfsjstest/entry/src/ohosTest/js/test/List.test.js
+++ b/storage/storagestatfsjstest/src/main/js/test/List.test.js
@@ -1,5 +1,5 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
+/*
+ * Copyright (C) 2021-2022 Huawei Device Co., Ltd.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
diff --git a/storage/storagestatfsjstest/entry/src/ohosTest/js/test/statfs.test.js b/storage/storagestatfsjstest/src/main/js/test/statfs.test.js
similarity index 94%
rename from storage/storagestatfsjstest/entry/src/ohosTest/js/test/statfs.test.js
rename to storage/storagestatfsjstest/src/main/js/test/statfs.test.js
index 65d356dfe407b5bb53bfee3b4a68b0c06460ab89..1a4b3875bd47ec64ddeb1aff1fe123455ade5fbb 100644
--- a/storage/storagestatfsjstest/entry/src/ohosTest/js/test/statfs.test.js
+++ b/storage/storagestatfsjstest/src/main/js/test/statfs.test.js
@@ -1,13 +1,13 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
+/*
+ * Copyright (C) 2021 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
+ * distributed under the License is distributed on an 'AS IS' BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
diff --git a/storage/storagestatfsjstest/entry/src/ohosTest/js/test/statvfs.test.js b/storage/storagestatfsjstest/src/main/js/test/statvfs.test.js
similarity index 95%
rename from storage/storagestatfsjstest/entry/src/ohosTest/js/test/statvfs.test.js
rename to storage/storagestatfsjstest/src/main/js/test/statvfs.test.js
index 90ed87afbc0fe528e78041362c7d7e1dbcde858c..0332956b3331184016bf14990d782559c158ad96 100644
--- a/storage/storagestatfsjstest/entry/src/ohosTest/js/test/statvfs.test.js
+++ b/storage/storagestatfsjstest/src/main/js/test/statvfs.test.js
@@ -1,296 +1,296 @@
-/**
- * Copyright (c) 2023 Huawei Device Co., Ltd.
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
-
-import {describe, it, expect, isIntNum, statvfs} from './Common';
-import featureAbility from '@ohos.ability.featureAbility';
-
-export default function statvfs_test() {
-describe('statvfs_test', function () {
-
- /**
- * @tc.number SUB_DF_STATFS_GET_FREE_SIZE_0000
- * @tc.name statvfs_test_get_free_size_async_000
- * @tc.desc Test getFreeSize() interfaces, when the path is a sandbox path, promise way back.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('statvfs_test_get_free_size_async_000', 0, async function (done) {
- try {
- let context = featureAbility.getContext();
- let data = await context.getFilesDir();
- let number = await statvfs.getFreeSize(data);
- console.log("getFreeSize getFilesDir===>" + (number / 1024));
- expect(isIntNum(number)).assertTrue();
- done();
- } catch (e) {
- console.log('statvfs_test_get_free_size_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_STATFS_GET_FREE_SIZE_0100
- * @tc.name statvfs_test_get_free_size_async_001
- * @tc.desc Test getFreeSize() interfaces, when the path is dev, callback way back.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('statvfs_test_get_free_size_async_001', 0, async function (done) {
- try {
- statvfs.getFreeSize("/dev", (err, number) => {
- if (err) {
- console.log('statvfs_test_get_free_size_async_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- console.log("getFreeSizeNumber dev===>:" + (number / 1024));
- expect(isIntNum(number)).assertTrue();
- done();
- });
- } catch (e) {
- console.log('statvfs_test_get_free_size_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_STATFS_GET_FREE_SIZE_0200
- * @tc.name statvfs_test_get_free_size_async_002
- * @tc.desc Test getFreeSize() interfaces, when the parameter type is wrong.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('statvfs_test_get_free_size_async_002', 0, async function (done) {
- try {
- await statvfs.getFreeSize(1);
- expect(false).assertTrue();
- } catch (e) {
- console.log('statvfs_test_get_free_size_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == "Invalid argument").assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_STATFS_GET_FREE_SIZE_0300
- * @tc.name statvfs_test_get_free_size_async_003
- * @tc.desc Test getFreeSize() interfaces, when there are no parameters.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('statvfs_test_get_free_size_async_003', 0, async function (done) {
- try {
- await statvfs.getFreeSize();
- expect(false).assertTrue();
- } catch (e) {
- console.log('statvfs_test_get_free_size_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == "Invalid argument").assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_STATFS_GET_FREE_SIZE_0400
- * @tc.name statvfs_test_get_free_size_async_004
- * @tc.desc Test getFreeSize() interfaces, when the path is empty.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('statvfs_test_get_free_size_async_004', 0, async function (done) {
- try {
- await statvfs.getFreeSize("");
- expect(false).assertTrue();
- } catch (e) {
- console.log('statvfs_test_get_free_size_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_STATFS_GET_FREE_SIZE_0500
- * @tc.name statvfs_test_get_free_size_async_005
- * @tc.desc Test getFreeSize() interfaces, when the path is empty.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('statvfs_test_get_free_size_async_005', 0, async function (done) {
- try {
- statvfs.getFreeSize("", (err) => {
- if (err) {
- console.log(
- 'statvfs_test_get_free_size_async_005 error package: {' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('statvfs_test_get_free_size_async_005 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_STATFS_GET_TOTAL_SIZE_0000
- * @tc.name statvfs_test_get_total_size_async_000
- * @tc.desc Test getTotalSize() interfaces, when the path is a sandbox path, promise way back.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('statvfs_test_get_total_size_async_000', 0, async function (done) {
-
- try {
- let context = featureAbility.getContext();
- let data = await context.getFilesDir();
- let number = await statvfs.getTotalSize(data);
- console.log("getTotalSizeNumber GetFilesDir====>:" + (number / 1024));
- expect(isIntNum(number)).assertTrue();
- done();
- } catch (e) {
- console.log('statvfs_test_get_total_size_async_000 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_STATFS_GET_TOTAL_SIZE_0100
- * @tc.name statvfs_test_get_total_size_async_001
- * @tc.desc Test getTotalSize() interfaces, when the path is dev, callback way back.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('statvfs_test_get_total_size_async_001', 0, async function (done) {
-
- try {
- statvfs.getTotalSize("/dev", (err, number) => {
- if (err) {
- console.log('statvfs_test_get_total_size_async_001 error package: ' + JSON.stringify(err));
- expect(false).assertTrue();
- }
- console.log("getTotalSizeNumber dev===>:" + (number / 1024));
- expect(isIntNum(number)).assertTrue();
- done();
- });
- } catch (e) {
- console.log('statvfs_test_get_total_size_async_001 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-
- /**
- * @tc.number SUB_DF_STATFS_GET_TOTAL_SIZE_0200
- * @tc.name statvfs_test_get_total_size_async_002
- * @tc.desc Test getTotalSize() interfaces, when the parameter type is wrong.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('statvfs_test_get_total_size_async_002', 0, async function (done) {
-
- try {
- await statvfs.getTotalSize(1);
- expect(false).assertTrue();
- } catch (e) {
- console.log('statvfs_test_get_total_size_async_002 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == "Invalid argument").assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_STATFS_GET_TOTAL_SIZE_0300
- * @tc.name statvfs_test_get_total_size_async_003
- * @tc.desc Test getTotalSize() interfaces, when there are no parameters.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('statvfs_test_get_total_size_async_003', 0, async function (done) {
-
- try {
- await statvfs.getTotalSize();
- expect(false).assertTrue();
- } catch (e) {
- console.log('statvfs_test_get_total_size_async_003 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900020 && e.message == "Invalid argument").assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_STATFS_GET_TOTAL_SIZE_0400
- * @tc.name statvfs_test_get_total_size_async_004
- * @tc.desc Test getTotalSize() interfaces, when the path is empty.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('statvfs_test_get_total_size_async_004', 0, async function (done) {
-
- try {
- await statvfs.getTotalSize("");
- expect(false).assertTrue();
- } catch (e) {
- console.log('statvfs_test_get_total_size_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
- done();
- }
- });
-
- /**
- * @tc.number SUB_DF_STATFS_GET_TOTAL_SIZE_0500
- * @tc.name statvfs_test_get_total_size_async_005
- * @tc.desc Test getTotalSize() interfaces, when the path is empty.
- * @tc.size MEDIUM
- * @tc.type Function
- * @tc.level Level 0
- * @tc.require
- */
- it('statvfs_test_get_total_size_async_005', 0, async function (done) {
-
- try {
- statvfs.getTotalSize("", (err) => {
- if (err) {
- console.log(
- 'statvfs_test_get_total_size_async_005 error package: {' + err.message + ', code: ' + err.code + '}');
- expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
- done();
- }
- });
- } catch (e) {
- console.log('statvfs_test_get_total_size_async_004 has failed for ' + e.message + ', code: ' + e.code);
- expect(false).assertTrue();
- }
- });
-});
-}
+/*
+ * Copyright (C) 2022 Huawei Device Co., Ltd.
+ * Licensed under the Apache License, Version 2.0 (the 'License');
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an 'AS IS' BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+import {describe, it, expect, isIntNum, statvfs} from './Common';
+import featureAbility from '@ohos.ability.featureAbility';
+
+export default function statvfs_test() {
+describe('statvfs_test', function () {
+
+ /**
+ * @tc.number SUB_DF_STATFS_GET_FREE_SIZE_0000
+ * @tc.name statvfs_test_get_free_size_async_000
+ * @tc.desc Test getFreeSize() interfaces, when the path is a sandbox path, promise way back.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('statvfs_test_get_free_size_async_000', 0, async function (done) {
+ try {
+ let context = featureAbility.getContext();
+ let data = await context.getFilesDir();
+ let number = await statvfs.getFreeSize(data);
+ console.log("getFreeSize getFilesDir===>" + (number / 1024));
+ expect(isIntNum(number)).assertTrue();
+ done();
+ } catch (e) {
+ console.log('statvfs_test_get_free_size_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_STATFS_GET_FREE_SIZE_0100
+ * @tc.name statvfs_test_get_free_size_async_001
+ * @tc.desc Test getFreeSize() interfaces, when the path is dev, callback way back.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('statvfs_test_get_free_size_async_001', 0, async function (done) {
+ try {
+ statvfs.getFreeSize("/dev", (err, number) => {
+ if (err) {
+ console.log('statvfs_test_get_free_size_async_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ console.log("getFreeSizeNumber dev===>:" + (number / 1024));
+ expect(isIntNum(number)).assertTrue();
+ done();
+ });
+ } catch (e) {
+ console.log('statvfs_test_get_free_size_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_STATFS_GET_FREE_SIZE_0200
+ * @tc.name statvfs_test_get_free_size_async_002
+ * @tc.desc Test getFreeSize() interfaces, when the parameter type is wrong.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('statvfs_test_get_free_size_async_002', 0, async function (done) {
+ try {
+ await statvfs.getFreeSize(1);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('statvfs_test_get_free_size_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == "Invalid argument").assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_STATFS_GET_FREE_SIZE_0300
+ * @tc.name statvfs_test_get_free_size_async_003
+ * @tc.desc Test getFreeSize() interfaces, when there are no parameters.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('statvfs_test_get_free_size_async_003', 0, async function (done) {
+ try {
+ await statvfs.getFreeSize();
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('statvfs_test_get_free_size_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == "Invalid argument").assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_STATFS_GET_FREE_SIZE_0400
+ * @tc.name statvfs_test_get_free_size_async_004
+ * @tc.desc Test getFreeSize() interfaces, when the path is empty.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('statvfs_test_get_free_size_async_004', 0, async function (done) {
+ try {
+ await statvfs.getFreeSize("");
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('statvfs_test_get_free_size_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_STATFS_GET_FREE_SIZE_0500
+ * @tc.name statvfs_test_get_free_size_async_005
+ * @tc.desc Test getFreeSize() interfaces, when the path is empty.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('statvfs_test_get_free_size_async_005', 0, async function (done) {
+ try {
+ statvfs.getFreeSize("", (err) => {
+ if (err) {
+ console.log(
+ 'statvfs_test_get_free_size_async_005 error package: {' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('statvfs_test_get_free_size_async_005 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_STATFS_GET_TOTAL_SIZE_0000
+ * @tc.name statvfs_test_get_total_size_async_000
+ * @tc.desc Test getTotalSize() interfaces, when the path is a sandbox path, promise way back.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('statvfs_test_get_total_size_async_000', 0, async function (done) {
+
+ try {
+ let context = featureAbility.getContext();
+ let data = await context.getFilesDir();
+ let number = await statvfs.getTotalSize(data);
+ console.log("getTotalSizeNumber GetFilesDir====>:" + (number / 1024));
+ expect(isIntNum(number)).assertTrue();
+ done();
+ } catch (e) {
+ console.log('statvfs_test_get_total_size_async_000 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_STATFS_GET_TOTAL_SIZE_0100
+ * @tc.name statvfs_test_get_total_size_async_001
+ * @tc.desc Test getTotalSize() interfaces, when the path is dev, callback way back.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('statvfs_test_get_total_size_async_001', 0, async function (done) {
+
+ try {
+ statvfs.getTotalSize("/dev", (err, number) => {
+ if (err) {
+ console.log('statvfs_test_get_total_size_async_001 error package: ' + JSON.stringify(err));
+ expect(false).assertTrue();
+ }
+ console.log("getTotalSizeNumber dev===>:" + (number / 1024));
+ expect(isIntNum(number)).assertTrue();
+ done();
+ });
+ } catch (e) {
+ console.log('statvfs_test_get_total_size_async_001 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_STATFS_GET_TOTAL_SIZE_0200
+ * @tc.name statvfs_test_get_total_size_async_002
+ * @tc.desc Test getTotalSize() interfaces, when the parameter type is wrong.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('statvfs_test_get_total_size_async_002', 0, async function (done) {
+
+ try {
+ await statvfs.getTotalSize(1);
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('statvfs_test_get_total_size_async_002 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == "Invalid argument").assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_STATFS_GET_TOTAL_SIZE_0300
+ * @tc.name statvfs_test_get_total_size_async_003
+ * @tc.desc Test getTotalSize() interfaces, when there are no parameters.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('statvfs_test_get_total_size_async_003', 0, async function (done) {
+
+ try {
+ await statvfs.getTotalSize();
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('statvfs_test_get_total_size_async_003 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900020 && e.message == "Invalid argument").assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_STATFS_GET_TOTAL_SIZE_0400
+ * @tc.name statvfs_test_get_total_size_async_004
+ * @tc.desc Test getTotalSize() interfaces, when the path is empty.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('statvfs_test_get_total_size_async_004', 0, async function (done) {
+
+ try {
+ await statvfs.getTotalSize("");
+ expect(false).assertTrue();
+ } catch (e) {
+ console.log('statvfs_test_get_total_size_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(e.code == 13900002 && e.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+
+ /**
+ * @tc.number SUB_DF_STATFS_GET_TOTAL_SIZE_0500
+ * @tc.name statvfs_test_get_total_size_async_005
+ * @tc.desc Test getTotalSize() interfaces, when the path is empty.
+ * @tc.size MEDIUM
+ * @tc.type Function
+ * @tc.level Level 0
+ * @tc.require
+ */
+ it('statvfs_test_get_total_size_async_005', 0, async function (done) {
+
+ try {
+ statvfs.getTotalSize("", (err) => {
+ if (err) {
+ console.log(
+ 'statvfs_test_get_total_size_async_005 error package: {' + err.message + ', code: ' + err.code + '}');
+ expect(err.code == 13900002 && err.message == 'No such file or directory').assertTrue();
+ done();
+ }
+ });
+ } catch (e) {
+ console.log('statvfs_test_get_total_size_async_004 has failed for ' + e.message + ', code: ' + e.code);
+ expect(false).assertTrue();
+ }
+ });
+});
+}
diff --git a/storage/storagefileurijstest/entry/src/ohosTest/resources/base/element/string.json b/storage/storagestatfsjstest/src/main/resources/base/element/string.json
similarity index 100%
rename from storage/storagefileurijstest/entry/src/ohosTest/resources/base/element/string.json
rename to storage/storagestatfsjstest/src/main/resources/base/element/string.json
diff --git a/storage/storagefileurijstest/entry/src/main/resources/base/media/icon.png b/storage/storagestatfsjstest/src/main/resources/base/media/icon.png
similarity index 100%
rename from storage/storagefileurijstest/entry/src/main/resources/base/media/icon.png
rename to storage/storagestatfsjstest/src/main/resources/base/media/icon.png