Maven Interview Questions

Advertisements


Dear readers, these Maven Interview Questions have been designed specially to get you acquainted with the nature of questions you may encounter during your interview for the subject of Maven. As per my experience good interviewers hardly plan to ask any particular question during your interview, normally questions start with some basic concept of the subject and later they continue based on further discussion and what you answer:

Q: What are the steps involved in project deployment?

A: Normally a deployment process consists of following steps:

  • Check-in the code from all projects in progress into the SVN or source code repository and tag it.

  • Download the complete source code from SVN.

  • Build the application.

  • Store the build output either WAR or EAR file to a common network location.

  • Get the file from network and deploy the file to the production site.

  • Updated the documentation with date and updated version number of the application.

Q: What is Maven?

A: Maven is a project management and comprehension tool. Maven provides developers a complete build lifecycle framework. Development team can automate the project's build infrastructure in almost no time as Maven uses a standard directory layout and a default build lifecycle.

Q: What does it mean when you say Maven uses Convention over Configuration?

A: Maven uses Convention over Configuration which means developers are not required to create build process themselves. Developers do not have to mention each and every configuration details.

Q: What are the aspects Maven manages?

A: Maven provides developers ways to manage following:

  • Builds

  • Documentation

  • Reporting

  • Dependencies

  • SCMs

  • Releases

  • Distribution

  • mailing list

Q: How do you know the version of mvn you are using?

A: Type the following command:

mvn --version
Q: What is POM?

A: POM stands for Project Object Model. It is fundamental Unit of Work in Maven. It is an XML file. It always resides in the base directory of the project as pom.xml. It contains information about the project and various configuration details used by Maven to build the project(s).

Q: What information does POM contain?

A:POM contains the some of the following configuration information:

  • project dependencies

  • plugins

  • goals

  • build profiles

  • project version

  • developers

  • mailing list

Q: What is Maven artifact?

A: An artifact is a file, usually a JAR that gets deployed to a Maven repository. A Maven build produces one or more artifacts, such as a compiled JAR and a "sources" JAR.

Each artifact has a group ID (usually a reversed domain name, like com.example.foo), an artifact ID (just a name), and a version string. The three together uniquely identify the artifact. A project's dependencies are specified as artifacts.

Q: What is Maven Build Lifecycle?

A: A Build Lifecycle is a well defined sequence of phases which define the order in which the goals are to be executed. Here phase represents a stage in life cycle.

Q: Name the 3 build lifecycle of Maven.

A: The three build lifecycles are:

  • clean:cleans up artifacts created by prior builds.

  • default (or build):This is used to build the application.

  • site: generates site documentation for the project.

Q: What is the command to quickly build your Maven site?

A: Type the command:

mvn site
Q: What would the command mvn clean do ?

A: This command removes the target directory with all the build data before starting the build process.

Q: What are the phases of a Maven Build Lifecycle?

A: Following are the phases:

  • validate: validate the project is correct and all necessary information is available.

  • compile: compile the source code of the project.

  • test: test the compiled source code using a suitable unit testing framework. These tests should not require the code be packaged or deployed

  • package: take the compiled code and package it in its distributable format, such as a JAR.

  • integration-test: process and deploy the package if necessary into an environment where integration tests can be run.

  • verify: run any checks to verify the package is valid and meets quality criteria.

  • install: install the package into the local repository, for use as a dependency in other projects locally.

  • deploy: done in an integration or release environment, copies the final package to the remote repository for sharing with other developers and projects.

Q: What is a goal in Maven terminology?

A: A goal represents a specific task which contributes to the building and managing of a project. It may be bound to zero or more build phases. A goal not bound to any build phase could be executed outside of the build lifecycle by direct invocation.

Q: What would this command do mvn clean dependency:copy-dependencies package?

A: This command will clean the project, copy the dependencies and package the project (executing all phases up to package).

Q: What phases does a Clean Lifecycle consist?

A: The clean lifecycle consists of the following phases:

  • pre-clean

  • clean

  • post-clean

Q: What phases does a Site Lifecycle consist?

A: The phases in Site Lifecycle are:

  • pre-site

  • site

  • post-site

  • site-deploy

Q: What is Build Profile?

A: A Build profile is a set of configuration values which can be used to set or override default values of Maven build. Using a build profile, you can customize build for different environments such as Production v/s Development environments.

Q: What are different types of Build Profiles?

A: Build profiles are of three types:

  • Per Project: Defined in the project POM file, pom.xml.

  • Per User: Defined in Maven settings xml file (%USER_HOME%/.m2/settings.xml).

  • Global: Defined in Maven global settings xml file (%M2_HOME%/conf/settings.xml)

Q: How can you activate profiles?

A: A Maven Build Profile can be activated in various ways:

  • Explicitly using command console input.

  • Through maven settings.

  • Based on environment variables (User/System variables).

  • OS Settings (for example, Windows family).

  • Present/missing files.

Q: What is a Maven Repository?

A: A repository is a place i.e. directory where all the project jars, library jar, plugins or any other project specific artifacts are stored and can be used by Maven easily.

Q: What types of Maven repository?

A: Maven repository are of three types: local, central, remote

Q: What is local repository?

A: Maven local repository is a folder location on your machine. It gets created when you run any maven command for the first time. Maven local repository keeps your project's all dependencies (library jars, plugin jars etc).

Q: What is the default location for your local repository?

A: ~/m2./repository.

Q: What is the command to install JAR file in local repository?

A: mvn install

Q: What is Central Repository?

A: It is repository provided by Maven community. It contains a large number of commonly used libraries. When Maven does not find any dependency in local repository, it starts searching in central repository using following URL: http://repo1.maven.org/maven2/.

Q: What is Remote Repository?

A: Sometimes, Maven does not find a mentioned dependency in central repository as well then it stops the build process and output error message to console. To prevent such situation, Maven provides concept of Remote Repository which is developer's own custom repository containing required libraries or other project jars.

Q: What is the sequence in which Maven searches for dependency libraries?

A: Following is the search pattern:

  • Step 1 - Search dependency in local repository, if not found, move to step 2 else if found then do the further processing.

  • Step 2 - Search dependency in central repository, if not found and remote repository/repositories is/are mentioned then move to step 4 else if found, then it is downloaded to local repository for future reference.

  • Step 3 - If a remote repository has not been mentioned, Maven simply stops the processing and throws error (Unable to find dependency).

  • Step 4 - Search dependency in remote repository or repositories, if found then it is downloaded to local repository for future reference otherwise Maven as expected stop processing and throws error (Unable to find dependency).

Q: Why are Maven Plugins used?

A: Maven Plugins are used to :

  • create jar file.

  • create war file.

  • compile code files.

  • unit testing of code

  • create project documentation.

  • create project reports.

Q: What are the types of Maven Plugins?

A: Maven provides following two types of Plugins:

  • Build plugins: They execute during the build and should be configured in the element of pom.xml

  • Reporting plugins: They execute during the site generation and they should be configured in the element of the pom.xml

Q: When does Maven use External Dependency concept?

A: Maven dependency management using concept of Maven Repositories (Local, Central, Remote). Suppose dependency is not available in any of remote repositories and central repository; in such scenarios Maven uses concept of External Dependency.

Q: What are the things you need to define for each external dependency?

A: External dependencies (library jar location) can be configured in pom.xml in same way as other dependencies.

  • Specify groupId same as name of the library.

  • Specify artifactId same as name of the library.

  • Specify scope as system.

  • Specify system path relative to project location.

Q: What is Archetype?

A: Archetype is a Maven plugin whose task is to create a project structure as per its template.

Q: What is the command to create a new project based on an archtype?

A: Type the following command:

mvn archetype:generate
Q: What is SNAPSHOT in Maven?

A: SNAPSHOT is a special version that indicates a current development copy. Unlike regular versions, Maven checks for a new SNAPSHOT version in a remote repository for every build.

Q: What is difference between Snapshot and Version?

A: In case of Version, if Maven once downloaded the mentioned version say data-service:1.0, it will never try to download a newer 1.0 available in repository. To download the updated code, data-service version is be upgraded to 1.1.

In case of SNAPSHOT, Maven will automatically fetch the latest SNAPSHOT (data-service:1.0-SNAPSHOT) everytime app-ui team build their project.

Q: What is transitive dependency in Maven?

A: Transitive dependency means to avoid needing to discover and specify the libraries that your own dependencies require, and including them automatically.

Q: What does dependency management mean in the context of transitive dependency?

A: It means to directly specify the versions of artifacts to be used when they are encountered in transitive dependencies. For an example project C can include B as a dependency in its dependencyManagement section and directly control which version of B is to be used when it is ever referenced.

Q: How Maven handles and determines what version of dependency will be used when multiple version of an artifact are encountered?

A: Maven determines what version of a dependency is to be used when multiple versions of an artifact are encountered. If two dependency versions are at the same depth in the dependency tree, the first declared dependency will be used. This is called dependency mediation.

Q: What is dependency scope? Name all the dependency scope.

A: Dependency scope includes dependencies as per the current stage of the build. Various Dependency Scopes are:

  • compile: This scope indicates that dependency is available in classpath of project. It is default scope.

  • provided: This scope indicates that dependency is to be provided by JDK or web-Server/Container at runtime.

  • runtime: This scope indicates that dependency is not required for compilation, but is required during execution.

  • test: This scope indicates that the dependency is only available for the test compilation and execution phases.

  • system: This scope indicates that you have to provide the system path.

  • import: This scope is only used when dependency is of type pom. This scope indicates that the specified POM should be replaced with the dependencies in that POM's section.

Q: What is the minimal set of information for matching a dependency references against a dependencyManagement section ?

A: {groupId,artifactId,type,classifier}.

Q: How do you reference a property defined in your pom.xml file?

A: To reference a property defined in your pom.xml, the property name uses the names of the XML elements that define the value, with "pom" being allowed as an alias for the project (root) element.

So ${pom.name} refers to the name of the project, ${pom.version} refers to the version of the project, ${pom.build.finalName} refers to the final name of the file created when the built project is packaged, etc.

Q: What are the default values for packaging element? If there is no packaging element defined? What is the default value for that?

A: Some of the valid packaging values are jar, war, ear and pom. If no packaging value has been specified, it will default to jar.

Q: What is the value for packaging element in pom for a project that is purely meta-data?

A: pom

Q: What is the use of execution element in pom file?

A: The <execution> element contains information's required for the execution of a plugin.

Q: What is a project's fully qualified artifact name?

A: <groupId>:<artifactId>:<version>

Q: If you do not define any information, where does your pom inherits that information from?

A: All POMs inherit from a parent (despite explicitly defined or not). This base POM is known as the Super POM, and contains values inherited by default.

Q: How profiles are specified in Maven?

A: Profiles are specified using a subset of the elements available in the POM itself.

Q: What are the elements in POM that a profile can modify when specified in the POM?

A: <repositories>, <pluginRepositories>,<dependencies>, <plugins> ,<properties>, <modules><reporting>,<dependencyManagement>,<distributionManagement>

Q: Why profile is used in Maven?

A: To give portability to projects ( e.g. windows, linux etc).

Q: What are the benefit of storing JARS/external dependencies in local repository instead of remote one?

A: It uses less storage, it makes checking out project quicker, non need for versioning JAR files.

Q: How can you build your project offline?

A: Use the command:

mvn o package.
Q: How do you exclude dependency?

A: Using the exclusion element.

Q: What is a system dependency?

A: Dependency with scope system are always available and are not looked up in repository, they are usually used to tell Maven about dependencies which are provided by the JDK or the VM. Thus, system dependencies are especially useful for resolving dependencies on artifacts which are now provided by the JDK.

Q: What is the use of optional dependency?

A: Any transitive dependency can be marked as optional using "optional" element. As example, A depends upon B and B depends upon C. Now B marked C as optional. Then A will not use C.

Q: What is dependency exclusion ?

A: Any transitive dependency can be exclude using "exclusion" element. As example, A depends upon B and B depends upon C then A can mark C as excluded.

Q: How can you run the clean plugin automatically during the build?

A: You can put the clean plugin inside the execution tag in pom.xml file.

Q: How to stop the propagation of plugins to child POMs?

A: set <inherited> to false.

Q: What does the "You cannot have two plugin executions with the same (or missing) elements" message mean?

A: It means that you have executed a plugin multiple times with the same <id>. Provide each <execution> with a unique <id> then it would be ok.

Q: What is a Mojo?

A: A mojo is a Maven plain Old Java Object. Each mojo is an executable goal in Maven, and a plugin is a distribution of one or more related mojos.

Q: What is difference between Apache Ant and Maven?

A: Ant is simply a toolbox whereas Maven is about the application of patterns in order to achieve an infrastructure which displays the characteristics of visibility, reusability, maintainability, and comprehensibility. It is wrong to consider Maven as a build tool and just a replacement for Ant.

What is Next ?

Further you can go through your past assignments you have done with the subject and make sure you are able to speak confidently on them. If you are fresher then interviewer does not expect you will answer very complex questions, rather you have to make your basics concepts very strong.

Second it really doesn't matter much if you could not answer few questions but it matters that whatever you answered, you must have answered with confidence. So just feel confident during your interview. We at tutorialspoint wish you best luck to have a good interviewer and all the very best for your future endeavor. Cheers :-)



Advertisements
Advertisements