Cloud Tools for IntelliJ IDEA is an open source project. We appreciate your help!
When filing an issue, please answer these questions:
- What version of IDEA are you using?
- What version of Java are you using?
- What did you do?
- What did you expect to see?
- What did you see instead?
All code can be checked out from our Github repository in the usual way. That is, clone the repository with HTTPS or SSH:
$ git clone https://github.com/GoogleCloudPlatform/gcloud-intellij.git
Cloning into 'gcloud-intellij'...
There are four modules:
- google-account-plugin: Google account management and preferences
- google-clout-tools: Cloud debugger and code inspections
- common-lib: Code shared between the above two
- common-test-lib: test infrastructure code
When adding new dependencies, the jar files are loaded from Maven Central when available. If Maven Central doesn't have the necessary version, the jar is placed in the third_party directory.
On Linux/Mac OS X we use gradle as our build system. Gradle is self-installing. This one command
$ ./gradlew buildPlugin
compiles everything, runs the tests, and builds the plugins. The output appears in google-account-plugin/build/distributions and google-cloud-tools-plugin/build/distributions.
Other useful targets while developing include:
- $ ./gradlew compileJava: compile
- $ ./gradlew test: run tests
- $ ./gradlew check: run static analysis tools
- $ ./gradlew clean: remove all build artifacts
- $ ./gradlew runIdea: run IntelliJ preconfigured with the plugins from this project.
- 'New project from existing sources'
- Select the root build.gradle file to import
- Git revert changes to the .idea folder because IDEA Gradle import blows it away (https://youtrack.jetbrains.com/issue/IDEA-146295)
The Cloud Tools on IntelliJ run configuration can be use to run or debug the project. To set which IntelliJ IDEA edition to launch when running or debugging, update the ideaEdition flag in gradle.properties using IU for Ultimate Edition and IC for Community Edition.
- First, please sign either individual or corporate contributor license agreement, whichever is applicable.
- Set your git user.email property to the address used for step 1. E.g.
If you're a Googler or other corporate contributor, use your corporate email address here, not your personal address.
git config --global user.email "[email protected]"
- Read the Google Java Style Guide
- Setup IntelliJ IDEA
- Install the error-prone plugin from the plugin repo and configure your project compiler to use it.
- Install the Google-java-style IntelliJ plugin
- Make sure to run Code -> Reformat with google-java-format at the beginning of every IDE session.
- Configure the IDE to automatically reformat your code and optimize imports.
- Hint - you can do this by configuring it to do so on git push.
- If you're not using IntelliJ you can run reformat from the command line using
gradlew googleJavaFormat
.
- Fork the repository into your own Github account.
- Please include unit tests for all new code. (Yes, we know not all existing code has tests. We're slowly fixing that, and contributions of tests for existing code are much appreciated.)
- Make sure all existing tests pass. (gradlew test)
- For significant user facing changes add your change to the 'Unreleased' section of CHANGELOG.md.
- Associate the change with an existing issue or file a new issue.
- Create a pull request and send it to gcloud-intellij:master.
Unless otherwise noted, our source files are distributed under the Apache license found in the LICENSE file.
A number of issues in the issue tracker have been tagged as "Help Wanted." These are relatively small, self-contained changes that are good places to start.
We have a custom JUnit TestRule
that reduces the amount of boilerplate code we have in our unit
tests. Notably, this rule handles a lot of the set-up and tear-down required for a proper IntelliJ
project context.
For example:
@Rule public final CloudToolsRule cloudToolsRule = new CloudToolsRule(this);
A summary of its features can be found below.
Always:
- Initializes the fields annotated with
@Mock
by callingMockitoAnnotations.initMocks(testInstance)
- Creates an
IdeaProjectTestFixture
, which sets up static application state for the IntelliJ SDK and creates aProject
Testing UI components:
If your unit test is testing platform UI components such as toolbars/panels/dialogs, then you should instantiate these components on the Swing event-dispatch thread.
For example:
ApplicationManager.getApplication().invokeAndWait(() -> // initialize your component);
Additional Annotations:
@TestService
:
- Annotates fields of any type, but usually accompanies a
@Mock
annotation - Before the test runs, it swaps the actual implementation of the service that is registered in the
application's
PicoContainer
with the field's value - After the test runs, it swaps the real implementation back
- Sample:
@Mock @TestService private CloudSdkService mockCloudSdkService; @Test public void myTest() { when(mockCloudSdkService.validateCloudSdk()).thenReturn(ImmutableSet.of()); // Do something that depends on this mocked call... }
@TestFixture
:
- Annotates fields of type
com.intellij.testFramework.fixtures.IdeaProjectTestFixture
- Injects the created
IdeaProjectTestFixture
into the annotated field, giving access to the underlyingProject
- Sample:
@TestFixture private IdeaProjectTestFixture testFixture; @Test public void myTest() { Project project = testFixture.getProject(); // Do something with the project... }
@TestModule
:
- Annotates fields of type
com.intellij.openapi.module.Module
- Creates a new
Module
and adds it to the test fixture'sProject
, then injects the value of the createdModule
into the annotated field - Optionally allows for the addition of a
Facet
to theModule
by specifying the ID of the associatedcom.intellij.facet.FacetType
- Samples:
@TestModule private Module myModule; @TestModule(facetTypeId = MyFacetType.ID) private Module myModuleWithFacet;
@TestFile
:
- Annotates fields of type
java.io.File
- Creates a new
File
with the given name and optionally the given contents - Manages the deletion of the file after the test is torn down
- Samples:
@TestFile(name = "my.file") private File myFile; @TestFile(name = "my-file-with.contents", contents = "Some contents") private File myFileWithContents;
Nothing here yet.