Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Allow to start daemon database container #360

Merged
merged 4 commits into from
Jun 11, 2017

Conversation

inikolaev
Copy link
Contributor

This PR fixes #359 by supporting new boolean option TC_DAEMON which prevents container from stopping when all connections are closed.

@@ -199,7 +203,7 @@ private Connection wrapConnection(final Connection connection, final JdbcDatabas

return new ConnectionWrapper(connection, () -> {
finalConnections.remove(connection);
if (finalConnections.isEmpty()) {
if (!isDaemon && finalConnections.isEmpty()) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Shouldn't you avoid starting and reuse the existing container if it exists?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This line only prevents running container from stopping if TC_DAEMON=true was specified in connection string.

ContainerDatabaseDriver maintains a mapping jdbcUrlContainerCache which maps JDBC connection string to the container instance. New container won't start If such a mapping exists.

My change basically ensures that this mapping is not removed once all connections are closed.

@kiview
Copy link
Member

kiview commented Jun 8, 2017

Do you think you can provide a test for this feature as well?

@inikolaev
Copy link
Contributor Author

I tried making a test in jdbc module but it turned out it doesn't actually start container and there's no access to container instance, unless I pass it into ConnectionWrapper or add some helper static method into ContainerDatabaseDriver.

I can try to use Mockito and I guess I need to register some mock JdbcDatabaseContainerProvider which will return mock JdbcDatabaseContainer and then assert whether stop() method has been called or not.

@bsideup
Copy link
Member

bsideup commented Jun 8, 2017

@inikolaev JDBC tests are here:
https://github.com/testcontainers/testcontainers-java/tree/master/modules/jdbc-test

@inikolaev
Copy link
Contributor Author

Added test, please have a look

@@ -70,6 +77,7 @@ public static void testCleanup() {
@Test
public void test() throws SQLException {
performSimpleTest(jdbcUrl);
performContainerStatusCheck(jdbcUrl);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Since we test just a single case of TC_DAEMON here, maybe it worth to create a separate test, without Parameterized runner?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I thought about that, but at the same time now it tests that container is stopped for other tests without TC_DAEMON set.

Can do either way, don't have a strong opinion on it.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would go with a separate test where you test both scenarios (with and without TC_DAEMON), just to make it clear if it's broken or not. IMO Parameterized runner seems to be misused in general in JDBCDriverTest :)
Thanks!

Copy link
Contributor Author

@inikolaev inikolaev Jun 8, 2017

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ok! One more thing, I see I'm getting a PMD violation about using package private method: ContainerDatabaseDriver.getContainer().
Would it be fine to make it public? I saw some classes use VisibleForTesting annotation, but I'm not sure if it makes any difference.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, VisibleForTesting should be used here

@@ -84,6 +88,27 @@ public void test() throws SQLException {
}
}

@Test
public void shouldStopContainerWhenAllConnectionsClosed() throws SQLException {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

please move these two tests to a separate Test class, otherwise, they will execute for every parameterized data entry

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ouch, didn't realize that :)

@inikolaev inikolaev force-pushed the daemon-container branch 2 times, most recently from f429d07 to fdf33ed Compare June 8, 2017 18:56
@bsideup
Copy link
Member

bsideup commented Jun 9, 2017

Looks good to me.
@rnorth can you take a look?

Copy link
Member

@rnorth rnorth left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good to me - only very minor suggestions, and a good contribution.
Thanks also for updating the docs!

Please could you also update the CHANGELOG file? I apologise that you're the first person I'm asking to do this, but we're trying to automate the release process a bit more and having changelog updates done in advance would probably be a good idea.

Please could you add something like this near the top of the changelog?

## UNRELEASED
### Changed
- Added `TC_DAEMON` JDBC URL flag to prevent `ContainerDatabaseDriver` from shutting down containers at the time all connections are closed.

/**
* Created by inikolaev on 08/06/2017.
*/
public class DatabaseDriverTest {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please could you rename to be slightly more specific? i.e., this could be called DatabaseDriverShutdownTest or something like that.

* @return an instance of database container or <code>null</code> if no container associated with JDBC URL
*/
@VisibleForTesting
public static JdbcDatabaseContainer getContainer(String jdbcUrl) {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If this is only for use in testing, couldn't we make it package-scoped? That way it doesn't become part of the public API.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It was package-private first, but that causes PMD violation when Codacy runs different checks. Any ideas on how to fix that?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would ignore the Codacy check and use package-scope.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is there a way to adjust PMD rules? Else a more serious issue might be missed due to the noise this issue will add to every build.

Copy link
Member

@kiview kiview Jun 10, 2017

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There are lot's of places in the existing codebase, where we're violating this rule. Since it's not a really useful rule if you want to use package-scope, I'd say we simply deactivate this pattern in Codacy. @rnorth are you okay with this?

@bsideup bsideup added this to the 1.3.1 milestone Jun 10, 2017
@inikolaev
Copy link
Contributor Author

Could someone trigger Travis build - seems like it was terminated for some reason, but is passes locally.

@rnorth
Copy link
Member

rnorth commented Jun 11, 2017

@inikolaev have restarted the build, sorry. Not quite sure why it hung there..

@bsideup
Copy link
Member

bsideup commented Jun 11, 2017

Green now :)
/cc @inikolaev @rnorth

@rnorth rnorth merged commit 05192e6 into testcontainers:master Jun 11, 2017
@rnorth
Copy link
Member

rnorth commented Jun 11, 2017

Merged, thank you @inikolaev !

@inikolaev
Copy link
Contributor Author

Awesome! 😄

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Keep container running for as long as JVM is running
5 participants