Add Docker Compose support for MS SQL Server using JDBC
Closes gh-35146pull/35185/head
parent
ad4f7577c7
commit
b5178afa21
@ -0,0 +1,91 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2012-2023 the original author or authors.
|
||||||
|
*
|
||||||
|
* Licensed 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
|
||||||
|
*
|
||||||
|
* https://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.springframework.boot.docker.compose.service.connection.sqlserver;
|
||||||
|
|
||||||
|
import org.springframework.boot.autoconfigure.jdbc.JdbcConnectionDetails;
|
||||||
|
import org.springframework.boot.docker.compose.core.RunningService;
|
||||||
|
import org.springframework.boot.docker.compose.service.connection.DockerComposeConnectionDetailsFactory;
|
||||||
|
import org.springframework.boot.docker.compose.service.connection.DockerComposeConnectionSource;
|
||||||
|
import org.springframework.boot.docker.compose.service.connection.jdbc.JdbcUrlBuilder;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@link DockerComposeConnectionDetailsFactory} to create {@link JdbcConnectionDetails}
|
||||||
|
* for a {@code mssql/server} service.
|
||||||
|
*
|
||||||
|
* @author Andy Wilkinson
|
||||||
|
*/
|
||||||
|
class MsSqlServerJdbcDockerComposeConnectionDetailsFactory
|
||||||
|
extends DockerComposeConnectionDetailsFactory<JdbcConnectionDetails> {
|
||||||
|
|
||||||
|
protected MsSqlServerJdbcDockerComposeConnectionDetailsFactory() {
|
||||||
|
super("mssql/server");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected JdbcConnectionDetails getDockerComposeConnectionDetails(DockerComposeConnectionSource source) {
|
||||||
|
return new MsSqlJdbcDockerComposeConnectionDetails(source.getRunningService());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@link JdbcConnectionDetails} backed by a {@code mssql/server}
|
||||||
|
* {@link RunningService}.
|
||||||
|
*/
|
||||||
|
static class MsSqlJdbcDockerComposeConnectionDetails extends DockerComposeConnectionDetails
|
||||||
|
implements JdbcConnectionDetails {
|
||||||
|
|
||||||
|
private static final JdbcUrlBuilder jdbcUrlBuilder = new JdbcUrlBuilder("sqlserver", 1433);
|
||||||
|
|
||||||
|
private final MsSqlServerEnvironment environment;
|
||||||
|
|
||||||
|
private final String jdbcUrl;
|
||||||
|
|
||||||
|
MsSqlJdbcDockerComposeConnectionDetails(RunningService service) {
|
||||||
|
super(service);
|
||||||
|
this.environment = new MsSqlServerEnvironment(service.env());
|
||||||
|
this.jdbcUrl = disableEncryptionIfNecessary(jdbcUrlBuilder.build(service, ""));
|
||||||
|
}
|
||||||
|
|
||||||
|
private String disableEncryptionIfNecessary(String jdbcUrl) {
|
||||||
|
if (jdbcUrl.contains(";encrypt=false;")) {
|
||||||
|
return jdbcUrl;
|
||||||
|
}
|
||||||
|
StringBuilder jdbcUrlBuilder = new StringBuilder(jdbcUrl);
|
||||||
|
if (!jdbcUrl.endsWith(";")) {
|
||||||
|
jdbcUrlBuilder.append(";");
|
||||||
|
}
|
||||||
|
jdbcUrlBuilder.append("encrypt=false;");
|
||||||
|
return jdbcUrlBuilder.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getUsername() {
|
||||||
|
return this.environment.getUsername();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getPassword() {
|
||||||
|
return this.environment.getPassword();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getJdbcUrl() {
|
||||||
|
return this.jdbcUrl;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,61 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2012-2023 the original author or authors.
|
||||||
|
*
|
||||||
|
* Licensed 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
|
||||||
|
*
|
||||||
|
* https://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.springframework.boot.docker.compose.service.connection.sqlserver;
|
||||||
|
|
||||||
|
import java.sql.Driver;
|
||||||
|
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
|
import org.springframework.boot.autoconfigure.jdbc.JdbcConnectionDetails;
|
||||||
|
import org.springframework.boot.docker.compose.service.connection.test.AbstractDockerComposeIntegrationTests;
|
||||||
|
import org.springframework.boot.jdbc.DatabaseDriver;
|
||||||
|
import org.springframework.jdbc.core.JdbcTemplate;
|
||||||
|
import org.springframework.jdbc.datasource.SimpleDriverDataSource;
|
||||||
|
import org.springframework.util.ClassUtils;
|
||||||
|
|
||||||
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Integration tests for {@link MsSqlServerJdbcDockerComposeConnectionDetailsFactory}
|
||||||
|
*
|
||||||
|
* @author Andy Wilkinson
|
||||||
|
*/
|
||||||
|
class MsSqlServerJdbcDockerComposeConnectionDetailsFactoryIntegrationTests
|
||||||
|
extends AbstractDockerComposeIntegrationTests {
|
||||||
|
|
||||||
|
MsSqlServerJdbcDockerComposeConnectionDetailsFactoryIntegrationTests() {
|
||||||
|
super("mssqlserver-compose.yaml");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
|
void runCreatesConnectionDetailsThatCanBeUsedToAccessDatabase() throws ClassNotFoundException, LinkageError {
|
||||||
|
JdbcConnectionDetails connectionDetails = run(JdbcConnectionDetails.class);
|
||||||
|
assertThat(connectionDetails.getUsername()).isEqualTo("SA");
|
||||||
|
assertThat(connectionDetails.getPassword()).isEqualTo("verYs3cret");
|
||||||
|
assertThat(connectionDetails.getJdbcUrl()).startsWith("jdbc:sqlserver://");
|
||||||
|
SimpleDriverDataSource dataSource = new SimpleDriverDataSource();
|
||||||
|
dataSource.setUrl(connectionDetails.getJdbcUrl());
|
||||||
|
dataSource.setUsername(connectionDetails.getUsername());
|
||||||
|
dataSource.setPassword(connectionDetails.getPassword());
|
||||||
|
dataSource.setDriverClass((Class<? extends Driver>) ClassUtils.forName(connectionDetails.getDriverClassName(),
|
||||||
|
getClass().getClassLoader()));
|
||||||
|
JdbcTemplate template = new JdbcTemplate(dataSource);
|
||||||
|
assertThat(template.queryForObject(DatabaseDriver.SQLSERVER.getValidationQuery(), Integer.class)).isEqualTo(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue