BUG-2179: split logging out of CodeGenerator
[yangtools.git] / yang / yang-maven-plugin / src / test / java / org / opendaylight / yangtools / yang2sources / plugin / GenerateSourcesTest.java
1 /*
2  * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
3  *
4  * This program and the accompanying materials are made available under the
5  * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6  * and is available at http://www.eclipse.org/legal/epl-v10.html
7  */
8 package org.opendaylight.yangtools.yang2sources.plugin;
9
10 import static org.hamcrest.CoreMatchers.containsString;
11 import static org.junit.Assert.assertEquals;
12 import static org.junit.Assert.assertNotNull;
13 import static org.junit.Assert.assertThat;
14 import static org.junit.Assert.assertTrue;
15 import static org.mockito.Matchers.any;
16 import static org.mockito.Mockito.doNothing;
17 import static org.mockito.Mockito.doReturn;
18 import static org.mockito.Mockito.mock;
19
20 import com.google.common.collect.Lists;
21
22 import java.io.File;
23 import java.io.IOException;
24 import java.util.Collection;
25 import java.util.Collections;
26 import java.util.Map;
27 import java.util.Set;
28
29 import org.apache.maven.model.Plugin;
30 import org.apache.maven.plugin.logging.Log;
31 import org.apache.maven.project.MavenProject;
32 import org.junit.Before;
33 import org.junit.Test;
34 import org.mockito.Mock;
35 import org.mockito.MockitoAnnotations;
36 import org.opendaylight.yangtools.yang.model.api.Module;
37 import org.opendaylight.yangtools.yang.model.api.SchemaContext;
38 import org.opendaylight.yangtools.yang2sources.plugin.ConfigArg.CodeGeneratorArg;
39 import org.opendaylight.yangtools.yang2sources.plugin.YangToSourcesProcessor.YangProvider;
40 import org.opendaylight.yangtools.yang2sources.spi.BasicCodeGenerator;
41 import org.opendaylight.yangtools.yang2sources.spi.MavenLogAware;
42 import org.opendaylight.yangtools.yang2sources.spi.MavenProjectAware;
43
44 public class GenerateSourcesTest {
45
46     private String yang;
47     private YangToSourcesMojo mojo;
48     private File outDir;
49     @Mock
50     private MavenProject project;
51     @Mock
52     private Plugin plugin;
53
54     @Before
55     public void setUp() throws Exception {
56         MockitoAnnotations.initMocks(this);
57
58         yang = new File(getClass().getResource("/yang/mock.yang").toURI()).getParent();
59         outDir = new File("/outputDir");
60         YangProvider mock = mock(YangProvider.class);
61         doNothing().when(mock).addYangsToMetaInf(any(Log.class), any(MavenProject.class), any(File.class),
62                 any(File[].class));
63
64         YangToSourcesProcessor processor = new YangToSourcesProcessor(mock(Log.class), new File(yang), new File[] {},
65                 Lists.newArrayList(new CodeGeneratorArg(GeneratorMock.class.getName(), "outputDir")), project, false,
66                 mock);
67         mojo = new YangToSourcesMojo(processor);
68         doReturn(new File("")).when(project).getBasedir();
69         doReturn(Collections.emptyList()).when(plugin).getDependencies();
70         doReturn(plugin).when(project).getPlugin(YangToSourcesMojo.PLUGIN_NAME);
71         mojo.setProject(project);
72     }
73
74     @Test
75     public void test() throws Exception {
76         mojo.execute();
77         assertEquals(1, GeneratorMock.called);
78         assertEquals(outDir, GeneratorMock.outputDir);
79         assertEquals(project, GeneratorMock.project);
80         assertNotNull(GeneratorMock.log);
81         assertTrue(GeneratorMock.additionalCfg.isEmpty());
82         assertThat(GeneratorMock.resourceBaseDir.toString(), containsString("target" + File.separator
83                 + "generated-sources" + File.separator + "spi"));
84     }
85
86     public static class GeneratorMock implements BasicCodeGenerator, MavenLogAware, MavenProjectAware {
87
88         private static int called = 0;
89         private static File outputDir;
90         private static Log log;
91         private static Map<String, String> additionalCfg;
92         private static File resourceBaseDir;
93         private static MavenProject project;
94
95         @Override
96         public Collection<File> generateSources(final SchemaContext context, final File outputBaseDir, final Set<Module> currentModules)
97                 throws IOException {
98             called++;
99             outputDir = outputBaseDir;
100             return Lists.newArrayList();
101         }
102
103         @Override
104         public void setLog(final Log log) {
105             GeneratorMock.log = log;
106         }
107
108         @Override
109         public void setAdditionalConfig(final Map<String, String> additionalConfiguration) {
110             GeneratorMock.additionalCfg = additionalConfiguration;
111         }
112
113         @Override
114         public void setResourceBaseDir(final File resourceBaseDir) {
115             GeneratorMock.resourceBaseDir = resourceBaseDir;
116
117         }
118
119         @Override
120         public void setMavenProject(final MavenProject project) {
121             GeneratorMock.project = project;
122         }
123     }
124
125 }