aboutsummaryrefslogtreecommitdiffstats
path: root/asdctool/src/test/java/org/openecomp/sdc/asdctool/migration/tasks/mig1806/SDCInstancesMigrationTest.java
blob: 2a55aaf1fa934a44ff15ac0e5a5edd9b4390eb79 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
package org.openecomp.sdc.asdctool.migration.tasks.mig1806;

import fj.data.Either;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.Mock;
import org.mockito.junit.MockitoJUnitRunner;
import org.openecomp.sdc.asdctool.migration.core.task.MigrationResult;
import org.openecomp.sdc.asdctool.migration.core.task.MigrationResult.MigrationStatus;
import org.openecomp.sdc.be.dao.janusgraph.JanusGraphOperationStatus;
import org.openecomp.sdc.be.dao.jsongraph.GraphVertex;
import org.openecomp.sdc.be.dao.jsongraph.JanusGraphDao;
import org.openecomp.sdc.be.datatypes.elements.ComponentInstanceDataDefinition;
import org.openecomp.sdc.be.datatypes.elements.CompositionDataDefinition;
import org.openecomp.sdc.be.datatypes.enums.ComponentTypeEnum;
import org.openecomp.sdc.be.model.jsonjanusgraph.enums.JsonConstantKeysEnum;
import org.openecomp.sdc.be.model.jsonjanusgraph.operations.NodeTemplateOperation;
import org.openecomp.sdc.be.model.operations.api.StorageOperationStatus;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import static org.junit.Assert.assertEquals;
import static org.mockito.ArgumentMatchers.any;
import static org.mockito.Mockito.when;

@RunWith(MockitoJUnitRunner.class)
public class SDCInstancesMigrationTest{
    @Mock
    private JanusGraphDao janusGraphDao;
    @Mock
    private NodeTemplateOperation nodeTemplateOperation;

    
    @Test
    public void testFailedMigration(){
        SDCInstancesMigration instancesMigration = new SDCInstancesMigration(janusGraphDao, nodeTemplateOperation);
        when(janusGraphDao.getByCriteria(any(), any(), any(), any() )).thenReturn(Either.right(
            JanusGraphOperationStatus.GENERAL_ERROR));
        
        MigrationResult migrate = instancesMigration.migrate();
        MigrationStatus migrationStatus = migrate.getMigrationStatus();
        assertEquals(MigrationStatus.FAILED, migrationStatus);
    }
    @Test
    public void testSuccessMigration(){
        SDCInstancesMigration instancesMigration = new SDCInstancesMigration(janusGraphDao, nodeTemplateOperation);
        List<GraphVertex> list = new ArrayList<>();
        GraphVertex vertexOrig = new GraphVertex();
        Map<String, CompositionDataDefinition> jsonComposition = new HashMap<>();
        CompositionDataDefinition composition = new CompositionDataDefinition();
        Map<String, ComponentInstanceDataDefinition> componentInstances = new HashMap<>();
        ComponentInstanceDataDefinition instance = new ComponentInstanceDataDefinition();
        componentInstances.put("instanceId", instance);
        composition.setComponentInstances(componentInstances);
        jsonComposition.put(JsonConstantKeysEnum.COMPOSITION.getValue(), composition);
        vertexOrig.setJson(jsonComposition);
        vertexOrig.setType(ComponentTypeEnum.SERVICE);
        list.add(vertexOrig);
        
        when(janusGraphDao.getByCriteria(any(), any(), any(), any() )).thenReturn(Either.left(list));
        when(nodeTemplateOperation.createInstanceEdge(vertexOrig, instance)).thenReturn(StorageOperationStatus.OK);
        
        MigrationResult migrate = instancesMigration.migrate();
        MigrationStatus migrationStatus = migrate.getMigrationStatus();
        assertEquals(MigrationStatus.COMPLETED, migrationStatus);
    }
}