"sgl-kernel/vscode:/vscode.git/clone" did not exist on "43118f5f2ad3aa37170e39fab807afa80471af85"
paiYarnTrainingService.test.ts 2.95 KB
Newer Older
liuzhe-lz's avatar
liuzhe-lz committed
1
2
// Copyright (c) Microsoft Corporation.
// Licensed under the MIT license.
3
4
5
6
7
8
9
10

'use strict';

import * as chai from 'chai';
import * as chaiAsPromised from 'chai-as-promised';
import * as fs from 'fs';
import * as tmp from 'tmp';
import * as component from '../../common/component';
11
import { TrialJobApplicationForm } from '../../common/trainingService';
12
13
import { cleanupUnitTest, prepareUnitTest } from '../../common/utils';
import { TrialConfigMetadataKey } from '../common/trialConfigMetadataKey';
14
import { PAIYarnTrainingService } from '../pai/paiYarn/paiYarnTrainingService';
15
16
17
18
19
20

// TODO: copy mockedTrail.py to local folder
const localCodeDir: string = tmp.dirSync().name
const mockedTrialPath: string = './training_service/test/mockedTrial.py'
fs.copyFileSync(mockedTrialPath, localCodeDir + '/mockedTrial.py')

21
describe('Unit Test for PAIYarnTrainingService', () => {
22
23
24
25
26
27
28
    let skip: boolean = false;
    let testPaiClusterInfo: any;
    let paiCluster: any;
    let paiTrialConfig : any;
    try {
        testPaiClusterInfo = JSON.parse(fs.readFileSync('../../.vscode/paiCluster.json', 'utf8'));
        paiCluster = `{\"userName\":\"${testPaiClusterInfo.userName}\",\"passWord\":\"${testPaiClusterInfo.passWord}\",\"host\":\"${testPaiClusterInfo.host}\"}`;
29
        paiTrialConfig = `{\"command\":\"echo hello && ls\",\"codeDir\":\"/tmp/nni/examples/trials/mnist",\"gpuNum\":\"1\",
30
31
32
33
34
35
\"cpuNum\":\"1\",\"memoryMB\":\"8196\",\"image\":\"openpai/pai.example.tensorflow\",\"dataDir\":\"\",\"outputDir\":\"\"}`;
    } catch (err) {
        console.log('Please configure rminfo.json to enable remote machine unit test.');
        skip = true;
    }

36
    let paiYarnTrainingService: PAIYarnTrainingService;
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53

    console.log(tmp.dirSync().name);

    before(() => {
        chai.should();
        chai.use(chaiAsPromised);
        prepareUnitTest();
    });

    after(() => {
        cleanupUnitTest();
    });

    beforeEach(() => {
        if (skip) {
            return;
        }
54
55
        paiYarnTrainingService = component.get(PAIYarnTrainingService);
        paiYarnTrainingService.run();
56
57
58
59
60
61
    });

    afterEach(() => {
        if (skip) {
            return;
        }
62
        paiYarnTrainingService.cleanUp();
63
64
65
66
67
68
69
    });

    it('Get PAI token', async () => {
        if (skip) {
            return;
        }
        console.log(`paiCluster is ${paiCluster}`)
70
71
        await paiYarnTrainingService.setClusterMetadata(TrialConfigMetadataKey.PAI_YARN_CLUSTER_CONFIG, paiCluster);
        await paiYarnTrainingService.setClusterMetadata(TrialConfigMetadataKey.TRIAL_CONFIG, paiTrialConfig);
72
73
74
75
        const form: TrialJobApplicationForm = {
            sequenceId: 0,
            hyperParameters: { value: '', index: 0 }
        };
76
        try {
77
            const trialDetail = await paiYarnTrainingService.submitTrialJob(form);
78
79
80
            chai.expect(trialDetail.status).to.be.equals('WAITING');
        } catch(error) {
            console.log('Submit job failed:' + error);
81
            chai.assert(error)
82
83
        }
    });
84
});