• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

future-architect / uroborosql / #764

13 Aug 2024 03:26PM UTC coverage: 91.218% (+0.02%) from 91.197%
#764

Pull #331

HidekiSugimoto189
add oracle v12-23 and Mariadb 5,10 dialect
Pull Request #331: add oracle v12-23 and Mariadb 5,10 dialect

43 of 46 new or added lines in 8 files covered. (93.48%)

288 existing lines in 22 files now uncovered.

8787 of 9633 relevant lines covered (91.22%)

0.91 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

59.38
/src/main/java/jp/co/future/uroborosql/coverage/CoverageData.java
1
/**
2
 * Copyright (c) 2017-present, Future Corporation
3
 *
4
 * This source code is licensed under the MIT license found in the
5
 * LICENSE file in the root directory of this source tree.
6
 */
7
package jp.co.future.uroborosql.coverage;
8

9
import java.security.MessageDigest;
10

11
import org.slf4j.Logger;
12
import org.slf4j.LoggerFactory;
13

14
/**
15
 * カバレッジログ出力用データクラス
16
 *
17
 * @author ota
18
 */
19
public class CoverageData {
20
        /** カバレッジロガー. */
21
        private static final Logger COVERAGE_LOG = LoggerFactory.getLogger("jp.co.future.uroborosql.sql.coverage");
1✔
22

23
        /** SQL名. */
24
        private final String sqlName;
25

26
        /** 変換前SQL. */
27
        private final String sql;
28

29
        /** MD5文字列. */
30
        private final String md5;
31

32
        /** 分岐情報. */
33
        private final PassedRoute passRoute;
34

35
        /**
36
         * コンストラクタ
37
         *
38
         * @param sqlName SQL名
39
         * @param sql SQL
40
         * @param passRoute 分岐情報
41
         */
42
        public CoverageData(final String sqlName, final String sql, final PassedRoute passRoute) {
1✔
43
                this.sqlName = sqlName;
1✔
44
                this.sql = sql;
1✔
45
                this.md5 = makeMd5(sql);
1✔
46
                this.passRoute = passRoute;
1✔
47
        }
1✔
48

49
        /**
50
         * MD5文字列の生成
51
         *
52
         * @param original 生成元文字列
53
         * @return MD5文字列
54
         */
55
        private String makeMd5(final String original) {
56
                try {
57
                        var digest = MessageDigest.getInstance("MD5");
1✔
58
                        var hash = digest.digest(original.getBytes("UTF-8"));
1✔
59
                        var builder = new StringBuilder();
1✔
60
                        for (var element : hash) {
1✔
61
                                if ((0xff & element) < 0x10) {
1✔
62
                                        builder.append("0" + Integer.toHexString(0xff & element));
1✔
63
                                } else {
64
                                        builder.append(Integer.toHexString(0xff & element));
1✔
65
                                }
66
                        }
67
                        return builder.toString();
1✔
68
                } catch (Exception ex) {
×
69
                        COVERAGE_LOG.error(ex.getMessage(), ex);
×
70
                }
UNCOV
71
                return "";
×
72
        }
73

74
        /**
75
         * JSON化
76
         *
77
         * @return JSON
78
         */
79
        public String toJSON() {
80
                var builder = new StringBuilder();
×
81
                builder.append("{\"sqlName\":");
×
82
                if (sqlName != null) {
×
UNCOV
83
                        builder.append(sqlName.replace('/', '/'));
×
84
                } else {
UNCOV
85
                        builder.append("");
×
86
                }
87
                builder.append(",\"md5\":").append(md5)
×
88
                                .append(",\"passRoute\":").append(passRoute)
×
89
                                .append("}");
×
UNCOV
90
                return builder.toString();
×
91
        }
92

93
        /**
94
         * SQL名取得.
95
         *
96
         * @return SQLファイルのルートからの相対パス(ファイル拡張子なし)
97
         */
98
        public String getSqlName() {
99
                return sqlName;
1✔
100
        }
101

102
        /**
103
         * 変換前SQL取得.
104
         *
105
         * @return 変換前SQL
106
         */
107
        public String getSql() {
108
                return sql;
1✔
109
        }
110

111
        /**
112
         * SQLのMD5取得.
113
         *
114
         * @return MD5
115
         */
116
        public String getMd5() {
117
                return md5;
1✔
118
        }
119

120
        /**
121
         * 分岐情報取得.
122
         *
123
         * @return 分岐情報
124
         */
125
        public PassedRoute getPassRoute() {
126
                return passRoute;
1✔
127
        }
128

129
        /**
130
         * {@inheritDoc}
131
         *
132
         * JSON化文字列を返す
133
         *
134
         * @see java.lang.Object#toString()
135
         */
136
        @Override
137
        public String toString() {
UNCOV
138
                return toJSON();
×
139
        }
140

141
}
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2026 Coveralls, Inc