| /* |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you under the Apache License, Version 2.0 (the |
| * "License"); you may not use this file except in compliance |
| * with the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, |
| * software distributed under the License is distributed on an |
| * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| * KIND, either express or implied. See the License for the |
| * specific language governing permissions and limitations |
| * under the License. |
| */ |
| package org.netbeans.modules.javascript2.jsdoc; |
| |
| import java.util.Iterator; |
| import java.util.List; |
| import java.util.Map.Entry; |
| import org.netbeans.modules.javascript2.editor.JsTestBase; |
| import org.netbeans.modules.javascript2.jsdoc.model.DeclarationElement; |
| import org.netbeans.modules.javascript2.jsdoc.model.DescriptionElement; |
| import org.netbeans.modules.javascript2.jsdoc.model.JsDocElement; |
| import org.netbeans.modules.javascript2.jsdoc.model.JsDocElementType; |
| import org.netbeans.modules.javascript2.jsdoc.model.NamedParameterElement; |
| import org.netbeans.modules.javascript2.model.api.ModelUtils; |
| import org.netbeans.modules.parsing.api.Snapshot; |
| import org.netbeans.modules.parsing.api.Source; |
| |
| /** |
| * |
| * @author Martin Fousek <marfous@netbeans.org> |
| */ |
| public class JsDocParserTest extends JsTestBase { |
| |
| public JsDocParserTest(String name) { |
| super(name); |
| } |
| private static final JsDocElementType[] expectedTypes = new JsDocElementType[]{ |
| // context sensitive type |
| JsDocElementType.CONTEXT_SENSITIVE, |
| // classic types |
| JsDocElementType.ARGUMENT, JsDocElementType.AUGMENTS, JsDocElementType.AUTHOR, JsDocElementType.BORROWS, |
| JsDocElementType.CLASS, JsDocElementType.CONSTANT, JsDocElementType.CONSTRUCTOR, JsDocElementType.CONSTRUCTS, |
| JsDocElementType.DEFAULT, JsDocElementType.DEPRECATED, JsDocElementType.DESCRIPTION, JsDocElementType.EVENT, |
| JsDocElementType.EXAMPLE, JsDocElementType.EXTENDS, JsDocElementType.FIELD, JsDocElementType.FILE_OVERVIEW, |
| JsDocElementType.FUNCTION, JsDocElementType.IGNORE, JsDocElementType.INNER, JsDocElementType.LENDS, |
| JsDocElementType.MEMBER_OF, JsDocElementType.NAME, JsDocElementType.NAMESPACE, |
| JsDocElementType.PARAM, JsDocElementType.PRIVATE, JsDocElementType.PROPERTY, JsDocElementType.PUBLIC, |
| JsDocElementType.REQUIRES, JsDocElementType.RETURN, JsDocElementType.RETURNS, JsDocElementType.SEE, |
| JsDocElementType.SINCE, JsDocElementType.STATIC, JsDocElementType.THROWS, JsDocElementType.TYPE, |
| JsDocElementType.VERSION |
| }; |
| |
| public void testParsedTypesForAsterisksComment() throws Exception { |
| checkElementTypes("testfiles/jsdoc/allTypesAsterisks.js"); |
| } |
| |
| public void testParsedTypesForNoAsteriskComment() throws Exception { |
| checkElementTypes("testfiles/jsdoc/allTypesNoAsterisk.js"); |
| } |
| |
| public void testParsedContextSensitiveContentNoAsterisk() throws Exception { |
| Source source = getTestSource(getTestFile("testfiles/jsdoc/allTypesNoAsterisk.js")); |
| List<? extends JsDocElement> tags = getFirstJsDocBlock(source.createSnapshot()).getTags(); |
| assertEquals(JsDocElementType.CONTEXT_SENSITIVE, tags.get(0).getType()); |
| assertEquals("This could be description", ((DescriptionElement) tags.get(0)).getDescription()); |
| } |
| |
| public void testParsedContextSensitiveContentAsterisks() throws Exception { |
| Source source = getTestSource(getTestFile("testfiles/jsdoc/allTypesAsterisks.js")); |
| List<? extends JsDocElement> tags = getFirstJsDocBlock(source.createSnapshot()).getTags(); |
| assertEquals(JsDocElementType.CONTEXT_SENSITIVE, tags.get(0).getType()); |
| assertEquals("This could be description", ((DescriptionElement) tags.get(0)).getDescription()); |
| } |
| |
| public void testNoTagsInBlockComment() throws Exception { |
| Source source = getTestSource(getTestFile("testfiles/jsdoc/blockComment.js")); |
| Iterator<Entry<Integer, JsDocComment>> iterator = JsDocParser.parse(source.createSnapshot()).entrySet().iterator(); |
| assertTrue(!iterator.hasNext()); |
| } |
| |
| public void testIssue188091() throws Exception { |
| Source source = getTestSource(getTestFile("testfiles/jsdoc/parser/issue188091.js")); |
| List<? extends JsDocElement> tags = getFirstJsDocBlock(source.createSnapshot()).getTags(); |
| assertEquals(JsDocElementType.CONTEXT_SENSITIVE, tags.get(0).getType()); |
| assertEquals("Placing container. Extends {@link goog.ui.Container} by adding\n" |
| + " the ability to place children at different content nodes.", ((DescriptionElement) tags.get(0)).getDescription()); |
| } |
| |
| public void testIssue217857() throws Exception { |
| Source source = getTestSource(getTestFile("testfiles/jsdoc/parser/issue217857.js")); |
| List<? extends JsDocElement> tags = getFirstJsDocBlock(source.createSnapshot()).getTags(); |
| assertEquals(JsDocElementType.DESCRIPTION, tags.get(0).getType()); |
| assertEquals("The `angular.module` @stop is a global place for creating and registering Angular modules. All\n" |
| + " modules (angular core or 3rd party) that should be available to an application must be\n" |
| + " registered using this mechanism.", ((DescriptionElement) tags.get(0)).getDescription()); |
| } |
| |
| public void testIssue224205() throws Exception { |
| Source source = getTestSource(getTestFile("testfiles/jsdoc/parser/issue224205.js")); |
| List<? extends JsDocElement> tags = getFirstJsDocBlock(source.createSnapshot()).getTags(); |
| assertEquals(JsDocElementType.PARAM, tags.get(0).getType()); |
| assertTrue(tags.get(0) instanceof NamedParameterElement); |
| NamedParameterElement namedParameter = (NamedParameterElement) tags.get(0); |
| assertEquals(1, namedParameter.getParamTypes().size()); |
| assertEquals("function(department, calls)", namedParameter.getParamTypes().get(0).getType()); |
| assertEquals(15, namedParameter.getParamTypes().get(0).getOffset()); |
| assertEquals("onSuccess", namedParameter.getParamName().getName()); |
| assertEquals(44, namedParameter.getParamName().getOffsetRange().getStart()); |
| } |
| |
| public void testIssue224265() throws Exception { |
| Source source = getTestSource(getTestFile("testfiles/jsdoc/parser/issue224265.js")); |
| List<? extends JsDocElement> tags = getFirstJsDocBlock(source.createSnapshot()).getTags(); |
| assertEquals(JsDocElementType.PARAM, tags.get(0).getType()); |
| assertTrue(tags.get(0) instanceof NamedParameterElement); |
| NamedParameterElement namedParameter = (NamedParameterElement) tags.get(0); |
| assertEquals(1, namedParameter.getParamTypes().size()); |
| assertEquals("uri:user", namedParameter.getParamTypes().get(0).getType()); |
| assertEquals(15, namedParameter.getParamTypes().get(0).getOffset()); |
| assertEquals("user", namedParameter.getParamName().getName()); |
| assertEquals(25, namedParameter.getParamName().getOffsetRange().getStart()); |
| assertEquals("the user", namedParameter.getParamDescription()); |
| } |
| |
| public void testIssue224552() throws Exception { |
| // Unfinished param type shouldn't lead to AIOOBE |
| Source source = getTestSource(getTestFile("testfiles/jsdoc/parser/issue224552.js")); |
| List<? extends JsDocElement> tags = getFirstJsDocBlock(source.createSnapshot()).getTags(); |
| assertEquals(JsDocElementType.PARAM, tags.get(0).getType()); |
| assertTrue(tags.get(0) instanceof NamedParameterElement); |
| } |
| |
| public void testIssue233176() throws Exception { |
| Source source = getTestSource(getTestFile("testfiles/jsdoc/issue233176.js")); |
| List<? extends JsDocElement> tags = getFirstJsDocBlock(source.createSnapshot()).getTags(); |
| assertEquals(JsDocElementType.TYPE, tags.get(0).getType()); |
| assertTrue(tags.get(0) instanceof DeclarationElement); |
| assertEquals("Number", ModelUtils.getDisplayName(((DeclarationElement) tags.get(0)).getDeclaredType())); |
| assertEquals(48, ((DeclarationElement) tags.get(0)).getDeclaredType().getOffset()); |
| } |
| |
| public void testParamGoogleCompilerSyntax_01() throws Exception { |
| Source source = getTestSource(getTestFile("testfiles/jsdoc/parser/paramGoogleCompilerSyntax.js")); |
| List<? extends JsDocElement> tags = getFirstJsDocBlock(source.createSnapshot()).getTags(); |
| assertEquals(JsDocElementType.PARAM, tags.get(0).getType()); |
| assertTrue(tags.get(0) instanceof NamedParameterElement); |
| NamedParameterElement namedParameter = (NamedParameterElement) tags.get(0); |
| assertEquals("String", namedParameter.getParamTypes().get(0).getType()); |
| assertEquals("somebody", namedParameter.getParamName().getName()); |
| } |
| |
| public void testIssue249834() throws Exception { |
| Source source = getTestSource(getTestFile("testfiles/jsdoc/parser/issue249834.js")); |
| List<? extends JsDocElement> tags = getFirstJsDocBlock(source.createSnapshot()).getTags(); |
| assertEquals(JsDocElementType.PARAM, tags.get(0).getType()); |
| assertTrue(tags.get(0) instanceof NamedParameterElement); |
| NamedParameterElement namedParameter = (NamedParameterElement) tags.get(0); |
| assertEquals("String", namedParameter.getParamTypes().get(0).getType()); |
| assertEquals("somebody", namedParameter.getParamName().getName()); |
| assertEquals(true, namedParameter.isOptional()); |
| // tested two spaces |
| assertEquals("John Doe", namedParameter.getDefaultValue()); |
| } |
| |
| private void checkElementTypes(String filePath) { |
| Source source = getTestSource(getTestFile(filePath)); |
| List<? extends JsDocElement> tags = getFirstJsDocBlock(source.createSnapshot()).getTags(); |
| for (int i = 0; i < expectedTypes.length; i++) { |
| assertEquals(expectedTypes[i], tags.get(i).getType()); |
| } |
| } |
| |
| private JsDocComment getFirstJsDocBlock(Snapshot snapshot) { |
| Iterator<Entry<Integer, JsDocComment>> iterator = JsDocParser.parse(snapshot).entrySet().iterator(); |
| return iterator.next().getValue(); |
| } |
| } |