Browse Source

Polishing.

Remove unecessary toString calls. Make Cast.create public to align with other factory methods. Fix AbstractSegment.toString

See #1066
Original pull request: #1071.
pull/1078/head
Mark Paluch 4 years ago
parent
commit
b1b5fe90da
No known key found for this signature in database
GPG Key ID: 4406B84C1661DCD1
  1. 5
      spring-data-relational/src/main/java/org/springframework/data/relational/core/sql/AbstractSegment.java
  2. 2
      spring-data-relational/src/main/java/org/springframework/data/relational/core/sql/AliasedExpression.java
  3. 8
      spring-data-relational/src/main/java/org/springframework/data/relational/core/sql/Cast.java
  4. 2
      spring-data-relational/src/main/java/org/springframework/data/relational/core/sql/Comparison.java
  5. 1
      spring-data-relational/src/main/java/org/springframework/data/relational/core/sql/Expressions.java
  6. 2
      spring-data-relational/src/main/java/org/springframework/data/relational/core/sql/Not.java
  7. 2
      spring-data-relational/src/main/java/org/springframework/data/relational/core/sql/SubselectExpression.java
  8. 37
      spring-data-relational/src/test/java/org/springframework/data/relational/core/sql/AbstractSegmentTests.java
  9. 2
      spring-data-relational/src/test/java/org/springframework/data/relational/core/sql/AbstractTestSegment.java

5
spring-data-relational/src/main/java/org/springframework/data/relational/core/sql/AbstractSegment.java

@ -15,8 +15,6 @@
*/ */
package org.springframework.data.relational.core.sql; package org.springframework.data.relational.core.sql;
import java.util.Arrays;
import org.springframework.util.Assert; import org.springframework.util.Assert;
import org.springframework.util.StringUtils; import org.springframework.util.StringUtils;
@ -70,7 +68,6 @@ abstract class AbstractSegment implements Segment {
@Override @Override
public String toString() { public String toString() {
return StringUtils.collectionToDelimitedString(Arrays.asList(children), ", ", getClass().getSimpleName() + "(", return getClass().getSimpleName() + "(" + StringUtils.arrayToDelimitedString(children, ", ") + ")";
")");
} }
} }

2
spring-data-relational/src/main/java/org/springframework/data/relational/core/sql/AliasedExpression.java

@ -57,6 +57,6 @@ class AliasedExpression extends AbstractSegment implements Aliased, Expression {
*/ */
@Override @Override
public String toString() { public String toString() {
return expression.toString() + " AS " + alias; return expression + " AS " + alias;
} }
} }

8
spring-data-relational/src/main/java/org/springframework/data/relational/core/sql/Cast.java

@ -18,7 +18,7 @@ package org.springframework.data.relational.core.sql;
import org.springframework.util.Assert; import org.springframework.util.Assert;
/** /**
* Represents a CAST expression like {@code CAST(something AS JSON}. * Represents a {@code CAST} expression like {@code CAST(something AS JSON}.
* *
* @author Jens Schauder * @author Jens Schauder
* @since 2.3 * @since 2.3
@ -39,13 +39,13 @@ public class Cast extends AbstractSegment implements Expression {
} }
/** /**
* Creates a new CAST expression. * Creates a new {@code CAST} expression.
* *
* @param expression the expression to cast. Must not be {@literal null}. * @param expression the expression to cast. Must not be {@literal null}.
* @param targetType the type to cast to. Must not be {@literal null}. * @param targetType the type to cast to. Must not be {@literal null}.
* @return guaranteed to be not {@literal null}. * @return the {@code CAST} for {@code expression} into {@code targetType}.
*/ */
static Expression create(Expression expression, String targetType) { public static Expression create(Expression expression, String targetType) {
return new Cast(expression, targetType); return new Cast(expression, targetType);
} }

2
spring-data-relational/src/main/java/org/springframework/data/relational/core/sql/Comparison.java

@ -116,6 +116,6 @@ public class Comparison extends AbstractSegment implements Condition {
@Override @Override
public String toString() { public String toString() {
return left.toString() + " " + comparator + " " + right.toString(); return left + " " + comparator + " " + right;
} }
} }

1
spring-data-relational/src/main/java/org/springframework/data/relational/core/sql/Expressions.java

@ -55,6 +55,7 @@ public abstract class Expressions {
/** /**
* @return a new {@link Cast} expression. * @return a new {@link Cast} expression.
* @since 2.3
*/ */
public static Expression cast(Expression expression, String targetType) { public static Expression cast(Expression expression, String targetType) {
return Cast.create(expression, targetType); return Cast.create(expression, targetType);

2
spring-data-relational/src/main/java/org/springframework/data/relational/core/sql/Not.java

@ -45,6 +45,6 @@ public class Not extends AbstractSegment implements Condition {
*/ */
@Override @Override
public String toString() { public String toString() {
return "NOT " + condition.toString(); return "NOT " + condition;
} }
} }

2
spring-data-relational/src/main/java/org/springframework/data/relational/core/sql/SubselectExpression.java

@ -38,6 +38,6 @@ public class SubselectExpression extends AbstractSegment implements Expression {
*/ */
@Override @Override
public String toString() { public String toString() {
return "(" + subselect.toString() + ")"; return "(" + subselect + ")";
} }
} }

37
spring-data-relational/src/test/java/org/springframework/data/relational/core/sql/AbstractSegmentTests.java

@ -0,0 +1,37 @@
/*
* Copyright 2021 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.data.relational.core.sql;
import static org.assertj.core.api.Assertions.*;
import org.junit.jupiter.api.Test;
/**
* Unit tests for {@link AbstractSegment}.
*
* @author Mark Paluch
*/
class AbstractSegmentTests {
@Test // GH-1066
void shouldReportToStringCorrectly() {
Table table = Table.create("foo");
AbstractSegment segment = new AbstractTestSegment(table.column("col1"), table.column("col2"));
assertThat(segment).hasToString("AbstractTestSegment(foo.col1, foo.col2)");
}
}

2
spring-data-relational/src/test/java/org/springframework/data/relational/core/sql/AbstractTestSegment.java

@ -20,7 +20,7 @@ package org.springframework.data.relational.core.sql;
* *
* @author Jens Schauder * @author Jens Schauder
*/ */
public class AbstractTestSegment extends AbstractSegment{ public class AbstractTestSegment extends AbstractSegment {
protected AbstractTestSegment(Segment... children) { protected AbstractTestSegment(Segment... children) {
super(children); super(children);
} }

Loading…
Cancel
Save