The error information is as follows:
1m[31mERROR in /var/lib/jenkins/workspace/CICD-libya-admin/src/main.ts[39m[22m
[2m59:9[22m No overload matches this call.
Overload 1 of 2, '(plugin: PluginObject<unknown> | PluginFunction<unknown>, options?: unknown): VueConstructor<Vue>', gave the following error.
Argument of type '{ new (): Plugin; prototype: Plugin; }' is not assignable to parameter of type 'PluginObject<unknown> | PluginFunction<unknown>'.
Property 'install' is missing in type '{ new (): Plugin; prototype: Plugin; }' but required in type 'PluginObject<unknown>'.
Overload 2 of 2, '(plugin: PluginObject<any> | PluginFunction<any>, ...options: any[]): VueConstructor<Vue>', gave the following error.
Argument of type '{ new (): Plugin; prototype: Plugin; }' is not assignable to parameter of type 'PluginObject<any> | PluginFunction<any>'.
Property 'install' is missing in type '{ new (): Plugin; prototype: Plugin; }' but required in type 'PluginObject<any>'.
After analyzing the error message, it should be caused by the inconsistent ts type. However, it was normal locally. After deleting node_modules and running again, the local error was exactly the same as the test environment.Then, open vs Code and find the Src/main.TS
file to view. An error was found in the following code.
data:image/s3,"s3://crabby-images/f0741/f0741c93c731f9883dee86eb51c1eb8ac6355872" alt=""
The type of vue.use method is:
data:image/s3,"s3://crabby-images/ee8cf/ee8cf1f8daa69b712b772d926c35f9fd0f3b06d2" alt=""
The type of vuecompositionapi is:
data:image/s3,"s3://crabby-images/556e7/556e72ec3c7b6e9813c39352fb9c7b46b5bd184f" alt=""
Preliminary inference: Both .ts files are included in node_modules, so the problem should lie in the version. So go to https://www.npmjs.com/ and search for @vue/composition-api.
data:image/s3,"s3://crabby-images/8bff5/8bff5b4aedea0a49efc95d833b330966698c5b7a" alt=""
It was found that the last release was a day ago, and the last successful build of Jenkins was on November 12th. Is it because we downloaded the latest version and caused the incompatibility?
With doubts, I opened the @vue/composition-api/package.json file in node_modules to view it, and sure enough, I downloaded the latest version.
data:image/s3,"s3://crabby-images/3e442/3e442358ab7cf93b3c15ec2567ec607d8c0a595a" alt=""
New question: isn’t the old version number defined in package.json? Why download to the latest version?
data:image/s3,"s3://crabby-images/96107/961072eec0ba70da380ed659e9d3b9ea228ab1d4" alt=""
With questions, I searched the Internet for “how to lock the dependent version defined in package.json” and found a solution
NPM shrinkwrap
can lock the dependent version defined in package.json
after execution, the npm-shrinkwrap.json file can be generated. With this file, we are not afraid that NPM and cnpm will download the latest version of dependencies to us.