Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Divide the package manager into separate components #2188

Merged
merged 66 commits into from
Apr 24, 2018
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
66 commits
Select commit Hold shift + click to select a range
6205e1d
use async await
akshita31 Apr 10, 2018
c632ab2
async await
akshita31 Apr 10, 2018
01f8cb1
remove promise
akshita31 Apr 10, 2018
56675b9
remove packagejson
akshita31 Apr 10, 2018
19ee685
resolve conflicts
akshita31 Apr 10, 2018
400ba5e
Feature tests running with refactored package manager
akshita31 Apr 10, 2018
5c4bfc0
trial to mock server
akshita31 Apr 11, 2018
3968900
package add
akshita31 Apr 11, 2018
cbf50af
package manager test not running
akshita31 Apr 11, 2018
8c09369
Mocking the server running
akshita31 Apr 11, 2018
c74aecf
Refactoring packages-1
akshita31 Apr 12, 2018
3e58f13
Test for the downloader running using the mock server
akshita31 Apr 13, 2018
5565a2e
Using network settings
akshita31 Apr 13, 2018
c8135b5
Changing the package path
akshita31 Apr 13, 2018
9afc874
Dividing packages.ts into separate components
akshita31 Apr 13, 2018
9cc0016
modification for network settings
akshita31 Apr 13, 2018
98e7e74
Clean up the downloaders
akshita31 Apr 13, 2018
e20a434
launch.json
akshita31 Apr 13, 2018
97e83ec
Clean up
akshita31 Apr 13, 2018
e7b520a
do not use filter
akshita31 Apr 13, 2018
c6bee5a
use filter async
akshita31 Apr 13, 2018
2dac16c
Use tmp file interface
akshita31 Apr 13, 2018
85d867f
Use tmpfile interface
akshita31 Apr 13, 2018
348e03a
merge master
akshita31 Apr 13, 2018
57d4bff
Check for the event stream
akshita31 Apr 14, 2018
9afa848
package json
akshita31 Apr 14, 2018
e5b0d65
Changes
akshita31 Apr 16, 2018
7e77a6e
Using FilePathResolver
akshita31 Apr 16, 2018
76e9780
Remove using
akshita31 Apr 16, 2018
47a18d1
Testing for normal and fallback case working
akshita31 Apr 16, 2018
441153a
Resolve the paths
akshita31 Apr 16, 2018
df2f874
Remove failing case
akshita31 Apr 16, 2018
4c2c15c
package installer test-1
akshita31 Apr 17, 2018
7e44a06
Add package installer test
akshita31 Apr 17, 2018
e218cb4
Create tmp asset
akshita31 Apr 17, 2018
b96fb22
Package Downloader test refactored
akshita31 Apr 17, 2018
10b6073
Rename files
akshita31 Apr 17, 2018
b9ac792
resolve compile issues
akshita31 Apr 17, 2018
10c6811
Clean up installer
akshita31 Apr 17, 2018
053efe3
Clean up the tests
akshita31 Apr 17, 2018
286fa7c
Nits
akshita31 Apr 18, 2018
12dfc3f
Rename packages
akshita31 Apr 18, 2018
24a5c03
Package installer test
akshita31 Apr 18, 2018
9e26124
PR feedback
akshita31 Apr 18, 2018
bccfa13
Package Filter test
akshita31 Apr 19, 2018
2b6ba72
Remove yauzl.d.ts
akshita31 Apr 19, 2018
7b2586f
Filter test
akshita31 Apr 19, 2018
df111f6
Added test for invalid zip file
akshita31 Apr 19, 2018
3ff44bb
method for getting the request options
akshita31 Apr 19, 2018
ebe6a2a
remove imports
akshita31 Apr 19, 2018
3a97968
please resolve the path
akshita31 Apr 20, 2018
93ea65c
remove latest in settings
akshita31 Apr 20, 2018
cc4a782
trial for travis
akshita31 Apr 20, 2018
13ad87d
Test run
akshita31 Apr 20, 2018
a6ed9a0
Package Manager test executing
akshita31 Apr 21, 2018
fdc9e0c
Use free port in package manager test
akshita31 Apr 21, 2018
16e1c88
Package Manager (using a https server running)
akshita31 Apr 23, 2018
1fe14a5
using http mock server
akshita31 Apr 23, 2018
bde8b49
Downloader test running using free port
akshita31 Apr 23, 2018
7abd6a6
Nits
akshita31 Apr 23, 2018
3e323af
clean up
akshita31 Apr 24, 2018
41b7b87
Making fallback url optional
akshita31 Apr 24, 2018
28fab5a
using else if
akshita31 Apr 24, 2018
45300ac
PR feedback
akshita31 Apr 24, 2018
573ca83
Package Error
akshita31 Apr 24, 2018
87fff8b
dispose if present
akshita31 Apr 24, 2018
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Package Manager test executing
  • Loading branch information
akshita31 committed Apr 21, 2018
commit a6ed9a05c8c5003f5adc9728a598e942f7b290b5
4 changes: 2 additions & 2 deletions src/CreateTmpAsset.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import * as tmp from 'tmp';
import { NestedError } from './packageManager/Package';
import { rimraf } from 'async-file';

export async function createTmpFile(): Promise<TmpAsset> {
export async function CreateTmpFile(): Promise<TmpAsset> {
const tmpFile = await new Promise<tmp.SynchrounousResult>((resolve, reject) => {
tmp.file({ prefix: 'package-' }, (err, path, fd, cleanupCallback) => {
if (err) {
Expand All @@ -27,7 +27,7 @@ export async function createTmpFile(): Promise<TmpAsset> {
};
}

export async function createTmpDir(unsafeCleanup: boolean): Promise<TmpAsset> {
export async function CreateTmpDir(unsafeCleanup: boolean): Promise<TmpAsset> {
const tmpDir = await new Promise<tmp.SynchrounousResult>((resolve, reject) => {
tmp.dir({ unsafeCleanup }, (err, path, cleanupCallback) => {
if (err) {
Expand Down
4 changes: 2 additions & 2 deletions src/omnisharp/OmnisharpDownloader.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ import { PackageInstallation, LogPlatformInfo, InstallationSuccess, Installation
import { EventStream } from '../EventStream';
import { NetworkSettingsProvider } from '../NetworkSettings';
import { DownloadAndInstallPackages } from '../packageManager/PackageManager';
import { createTmpFile, TmpAsset } from '../CreateTmpAsset';
import { CreateTmpFile, TmpAsset } from '../CreateTmpAsset';
import { DownloadFile } from '../packageManager/FileDownloader';
import { ResolveFilePaths } from '../packageManager/PackageFilePathResolver';

Expand Down Expand Up @@ -49,7 +49,7 @@ export class OmnisharpDownloader {
let tmpFile: TmpAsset;
try {
this.eventStream.post(new InstallationProgress(installationStage, 'Getting latest build information...'));
tmpFile = await createTmpFile();
tmpFile = await CreateTmpFile();
await DownloadFile(tmpFile.fd, description, url, "", this.eventStream, this.provider);
return fs.readFileSync(tmpFile.name, 'utf8');
}
Expand Down
6 changes: 6 additions & 0 deletions src/packageManager/PackageFilterer.ts
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,12 @@ function filterPlatformPackages(packages: Package[], platformInfo: PlatformInfor
async function filterAlreadyInstalledPackages(packages: Package[]): Promise<Package[]> {
return filterAsync(packages, async (pkg: Package) => {
//If the file is present at the install test path then filter it
let testPath = ResolvePackageTestPath(pkg);
if (!testPath) {
//if there is no testPath specified then we will not filter it
return true;
}

return !(await util.fileExists(ResolvePackageTestPath(pkg)));
});
}
4 changes: 2 additions & 2 deletions src/packageManager/PackageManager.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ import { InstallPackage } from './ZipInstaller';
import { EventStream } from '../EventStream';
import { NetworkSettingsProvider } from "../NetworkSettings";
import { filterPackages } from "./PackageFilterer";
import { createTmpFile, TmpAsset } from "../CreateTmpAsset";
import { CreateTmpFile, TmpAsset } from "../CreateTmpAsset";

//Package manager needs a list of packages to be filtered based on platformInfo then download and install them
//Note that the packages that this component will install needs absolute paths for the installPath, intsallTestPath and the binaries
Expand All @@ -20,7 +20,7 @@ export async function DownloadAndInstallPackages(packages: Package[], provider:
if (filteredPackages) {
for (let pkg of filteredPackages) {
try {
tmpFile = await createTmpFile();
tmpFile = await CreateTmpFile();
await DownloadFile(tmpFile.fd, pkg.description, pkg.url, pkg.fallbackUrl, eventStream, provider);
await InstallPackage(tmpFile.fd, pkg.description, pkg.installPath, pkg.binaries, eventStream);
}
Expand Down
5 changes: 3 additions & 2 deletions test/unitTests/Packages/FileDownloader.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,14 +9,15 @@ import * as util from '../../../src/common';
import { EventStream } from '../../../src/EventStream';
import { DownloadFile } from '../../../src/packageManager/FileDownloader';
import NetworkSettings from '../../../src/NetworkSettings';
import { TmpAsset, createTmpFile } from '../../../src/CreateTmpAsset';
import { TmpAsset, CreateTmpFile } from '../../../src/CreateTmpAsset';
import { BaseEvent, DownloadStart, DownloadSizeObtained, DownloadProgress, DownloadSuccess, DownloadFallBack, DownloadFailure } from '../../../src/omnisharp/loggingEvents';

let ServerMock = require("mock-http-server");
chai.use(require("chai-as-promised"));
chai.use(require('chai-arrays'));
let expect = chai.expect;

//to do:look into http url thing
suite("FileDownloader", () => {
let server = new ServerMock({ host: "localhost", port: 9000 },
{
Expand Down Expand Up @@ -46,7 +47,7 @@ suite("FileDownloader", () => {

setup(async () => {
await new Promise(resolve => server.start(resolve));
tmpFile = await createTmpFile();
tmpFile = await CreateTmpFile();
util.setExtensionPath(tmpFile.name);
eventBus = [];
server.on(requestOptions);
Expand Down
4 changes: 2 additions & 2 deletions test/unitTests/Packages/PackageFilterer.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
*--------------------------------------------------------------------------------------------*/
import * as chai from 'chai';
import * as util from '../../../src/common';
import { createTmpFile, TmpAsset } from "../../../src/CreateTmpAsset";
import { CreateTmpFile, TmpAsset } from "../../../src/CreateTmpAsset";
import { PlatformInformation } from "../../../src/platform";
import { filterPackages } from "../../../src/packageManager/PackageFilterer";
import { ResolveFilePaths } from "../../../src/packageManager/PackageFilePathResolver";
Expand Down Expand Up @@ -50,7 +50,7 @@ suite('PackageFilterer', () => {
];

setup(async () => {
tmpFile = await createTmpFile();
tmpFile = await CreateTmpFile();
packages[1].installTestPath = tmpFile.name;
util.setExtensionPath(extensionPath);
// we need to set the extension path because fileresolver uses it
Expand Down
91 changes: 91 additions & 0 deletions test/unitTests/Packages/PackageManager.test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,91 @@
/*---------------------------------------------------------------------------------------------
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for license information.
*--------------------------------------------------------------------------------------------*/

import * as https from 'https';
import * as fs from 'fs';
import * as path from 'path';
import * as chai from 'chai';
import * as util from '../../../src/common';
import { CreateTmpDir, TmpAsset } from '../../../src/CreateTmpAsset';
import { Binaries, Files, createTestZipAsync } from '../testAssets/CreateTestZip';
import { Package } from '../../../src/packageManager/Package';
import { DownloadAndInstallPackages } from '../../../src/packageManager/PackageManager';
import NetworkSettings from '../../../src/NetworkSettings';
import { PlatformInformation } from '../../../src/platform';
import { EventStream } from '../../../src/EventStream';
import { BaseEvent, DownloadStart, DownloadSizeObtained, DownloadProgress, DownloadSuccess, InstallationProgress } from '../../../src/omnisharp/loggingEvents';

chai.use(require("chai-as-promised"));
let expect = chai.expect;

suite("Package Manager", () => {
let tmpSourceDir: TmpAsset;
let tmpInstallDir: TmpAsset;
let server: https.Server;
let testDirPath: string;
let allFiles: Array<{ content: string, path: string }>;
let installationPath: string;
let eventBus: Array<BaseEvent>;
let packages: Package[];

const packageDescription = "Test Package";
const eventStream = new EventStream();
eventStream.subscribe(event => eventBus.push(event));

const platformInfo = new PlatformInformation("win32", "x86");
const networkSettingsProvider = () => new NetworkSettings(undefined, false);
const options = {
key: fs.readFileSync("test/unitTests/testAssets/private.pem"),
cert: fs.readFileSync("test/unitTests/testAssets/public.pem")
};

setup(async () => {
eventBus = [];
tmpSourceDir = await CreateTmpDir(true);
tmpInstallDir = await CreateTmpDir(true);
installationPath = tmpInstallDir.name;
packages = [<Package>{ url: "https://localhost:8000", description: packageDescription, installPath: installationPath }];
allFiles = [...Files, ...Binaries];
testDirPath = tmpSourceDir.name + "/test.zip";
await createTestZipAsync(testDirPath, allFiles);
server = https.createServer(options, (req, response) => {
let stat = fs.statSync(testDirPath);
response.writeHead(200, {
'Content-Type': 'application/zip',
'Content-Length': stat.size
});

let readStream = fs.createReadStream(testDirPath);
readStream.pipe(response);
}).listen(8000);
});

test("Downloads the package and installs at the specified path", async () => {
await DownloadAndInstallPackages(packages, networkSettingsProvider, platformInfo, eventStream);
for (let elem of allFiles) {
let filePath = path.join(installationPath, elem.path);
expect(await util.fileExists(filePath)).to.be.true;
}
});

test("Events are created in the correct order", async () => {
let eventsSequence = [
new DownloadStart(packageDescription),
new DownloadSizeObtained(396),
new DownloadProgress(100, packageDescription),
new DownloadSuccess(' Done!'),
new InstallationProgress('installPackages', packageDescription)
];

await DownloadAndInstallPackages(packages, networkSettingsProvider, platformInfo, eventStream);
expect(eventBus).to.be.deep.equal(eventsSequence);
});

teardown(() => {
tmpSourceDir.dispose();
tmpInstallDir.dispose();
server.close();
});
});
58 changes: 7 additions & 51 deletions test/unitTests/Packages/ZipInstaller.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,12 +7,12 @@ import * as fs from 'async-file';
import * as path from 'path';
import * as chai from 'chai';
import * as util from '../../../src/common';
import * as archiver from 'archiver';
import { createTmpDir, TmpAsset, createTmpFile } from '../../../src/CreateTmpAsset';
import { CreateTmpDir, TmpAsset, CreateTmpFile } from '../../../src/CreateTmpAsset';
import { InstallPackage } from '../../../src/packageManager/ZipInstaller';
import { EventStream } from '../../../src/EventStream';
import { PlatformInformation } from '../../../src/platform';
import { BaseEvent, InstallationProgress } from '../../../src/omnisharp/loggingEvents';
import { Files, Binaries, createTestZipAsync } from '../testAssets/CreateTestZip';

chai.use(require("chai-as-promised"));
let expect = chai.expect;
Expand All @@ -25,25 +25,6 @@ suite('ZipInstaller', () => {
let txtFile: TmpAsset;
let installationPath: string;

const files = [
{
content: "File 1",
path: "file1.txt",

},
{
content: "File 2",
path: "folder/file2.txt"
}
];

const binaries = [
{
content: "Binary 1",
path: "binary1.txt"
},
];

const fileDescription = "somefile";
const eventStream = new EventStream();
let eventBus: BaseEvent[];
Expand All @@ -52,11 +33,11 @@ suite('ZipInstaller', () => {

setup(async () => {
eventBus = [];
tmpSourceDir = await createTmpDir(true);
tmpInstallDir = await createTmpDir(true);
tmpSourceDir = await CreateTmpDir(true);
tmpInstallDir = await CreateTmpDir(true);
installationPath = tmpInstallDir.name;
txtFile = await createTmpFile();
allFiles = [...files, ...binaries];
txtFile = await CreateTmpFile();
allFiles = [...Files, ...Binaries];
testDirPath = tmpSourceDir.name + "/test.zip";
await createTestZipAsync(testDirPath, allFiles);
zipFileDescriptor = await fs.open(path.resolve(testDirPath), 'r');
Expand All @@ -81,7 +62,7 @@ suite('ZipInstaller', () => {

test('The folder is unzipped and the binaries have the expected permissions(except on Windows)', async () => {
if (!((await PlatformInformation.GetCurrent()).isWindows())) {
let resolvedBinaryPaths = binaries.map(binary => path.join(installationPath, binary.path));
let resolvedBinaryPaths = Binaries.map(binary => path.join(installationPath, binary.path));
await InstallPackage(zipFileDescriptor, fileDescription, installationPath, resolvedBinaryPaths, eventStream);
for (let binaryPath of resolvedBinaryPaths) {
expect(await util.fileExists(binaryPath)).to.be.true;
Expand All @@ -105,29 +86,4 @@ suite('ZipInstaller', () => {
tmpSourceDir.dispose();
tmpInstallDir.dispose();
});

async function createTestZipAsync(dirPath: string, filesToAdd: Array<{ content: string, path: string }>): Promise<{}> {
let output = fs.createWriteStream(dirPath);

return new Promise((resolve, reject) => {
output.on('close', function () {
resolve(); // the installer needs to wait for the filestream to be closed here
});

let archive = archiver('zip');
archive.on('warning', function (err: any) {
if (err.code === 'ENOENT') {
console.log(err);
} else {
// throw error
reject(err);
}
});

archive.on('error', reject);
archive.pipe(output);
filesToAdd.forEach(elem => archive.append(elem.content, { name: elem.path }));
archive.finalize();
});
}
});
52 changes: 52 additions & 0 deletions test/unitTests/testAssets/CreateTestZip.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
/*---------------------------------------------------------------------------------------------
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for license information.
*--------------------------------------------------------------------------------------------*/

import * as archiver from 'archiver';
import * as fs from 'async-file';

export const Files = [
{
content: "File 1",
path: "file1.txt",

},
{
content: "File 2",
path: "folder/file2.txt"
}
];

export const Binaries = [
{
content: "Binary 1",
path: "binary1.txt"
},
];


export async function createTestZipAsync(dirPath: string, filesToAdd: Array<{ content: string, path: string }>): Promise<{}> {
let output = fs.createWriteStream(dirPath);

return new Promise((resolve, reject) => {
output.on('close', function () {
resolve(); // the installer needs to wait for the filestream to be closed here
});

let archive = archiver('zip');
archive.on('warning', function (err: any) {
if (err.code === 'ENOENT') {
console.log(err);
} else {
// throw error
reject(err);
}
});

archive.on('error', reject);
archive.pipe(output);
filesToAdd.forEach(elem => archive.append(elem.content, { name: elem.path }));
archive.finalize();
});
}