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

HicServices / RDMP / 6245535001

20 Sep 2023 07:44AM UTC coverage: 57.013%. First build
6245535001

push

github

web-flow
8.1.0 Release (#1628)

* Bump Newtonsoft.Json from 13.0.1 to 13.0.2

Bumps [Newtonsoft.Json](https://github.com/JamesNK/Newtonsoft.Json) from 13.0.1 to 13.0.2.
- [Release notes](https://github.com/JamesNK/Newtonsoft.Json/releases)
- [Commits](https://github.com/JamesNK/Newtonsoft.Json/compare/13.0.1...13.0.2)

---
updated-dependencies:
- dependency-name: Newtonsoft.Json
  dependency-type: direct:production
  update-type: version-update:semver-patch
...

Signed-off-by: dependabot[bot] <support@github.com>

* Bump NLog from 5.0.5 to 5.1.0

Bumps [NLog](https://github.com/NLog/NLog) from 5.0.5 to 5.1.0.
- [Release notes](https://github.com/NLog/NLog/releases)
- [Changelog](https://github.com/NLog/NLog/blob/dev/CHANGELOG.md)
- [Commits](https://github.com/NLog/NLog/compare/v5.0.5...v5.1.0)

---
updated-dependencies:
- dependency-name: NLog
  dependency-type: direct:production
  update-type: version-update:semver-minor
...

Signed-off-by: dependabot[bot] <support@github.com>

* Bump NLog from 5.0.5 to 5.1.0

* Fix -r flag - should have been --results-directory all along

* Bump Newtonsoft.Json from 13.0.1 to 13.0.2

* Bump YamlDotNet from 12.0.2 to 12.1.0

Bumps [YamlDotNet](https://github.com/aaubry/YamlDotNet) from 12.0.2 to 12.1.0.
- [Release notes](https://github.com/aaubry/YamlDotNet/releases)
- [Commits](https://github.com/aaubry/YamlDotNet/compare/v12.0.2...v12.1.0)

---
updated-dependencies:
- dependency-name: YamlDotNet
  dependency-type: direct:production
  update-type: version-update:semver-minor
...

Signed-off-by: dependabot[bot] <support@github.com>

* Bump Moq from 4.18.2 to 4.18.3

Bumps [Moq](https://github.com/moq/moq4) from 4.18.2 to 4.18.3.
- [Release notes](https://github.com/moq/moq4/releases)
- [Changelog](https://github.com/moq/moq4/blob/main/CHANGELOG.md)
- [Commits](https://github.com/moq/moq4/compare/v4.18.2...v4.18.3)

---
updated-dependencies:
- dependency-name: Moq
... (continued)

10732 of 20257 branches covered (0.0%)

Branch coverage included in aggregate %.

48141 of 48141 new or added lines in 1086 files covered. (100.0%)

30685 of 52388 relevant lines covered (58.57%)

7387.88 hits per line

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

75.56
/Rdmp.Core/ReusableLibraryCode/DatabaseCommandHelper.cs
1
// Copyright (c) The University of Dundee 2018-2019
2
// This file is part of the Research Data Management Platform (RDMP).
3
// RDMP is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
4
// RDMP is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
5
// You should have received a copy of the GNU General Public License along with RDMP. If not, see <https://www.gnu.org/licenses/>.
6

7
using System;
8
using System.Collections.Generic;
9
using System.Data.Common;
10
using System.Linq;
11
using FAnsi;
12
using FAnsi.Discovery;
13
using FAnsi.Implementation;
14
using FAnsi.Implementations.MicrosoftSQL;
15
using FAnsi.Implementations.MySql;
16
using FAnsi.Implementations.Oracle;
17
using FAnsi.Implementations.PostgreSql;
18
using Microsoft.Data.SqlClient;
19
using MySqlConnector;
20
using Npgsql;
21
using Oracle.ManagedDataAccess.Client;
22
using Rdmp.Core.ReusableLibraryCode.Performance;
23

24
namespace Rdmp.Core.ReusableLibraryCode;
25

26
/// <summary>
27
/// Provides Cross Database Platform Type translation e.g. GetCommand returns SqlCommand when passed an SqlConnection and a MySqlCommand when passed a
28
/// MySqlConnection (etc).  Also provides central debugging/performance evaluation of the queries RDMP is using to access Catalogue databases etc via
29
/// installing a ComprehensiveQueryPerformanceCounter.
30
/// </summary>
31
public class DatabaseCommandHelper
32
{
33
    private static readonly Dictionary<DatabaseType, IImplementation> _dbConHelpersByType = new()
4✔
34
    {
4✔
35
        { DatabaseType.MySql, new MySqlImplementation() },
4✔
36
        { DatabaseType.Oracle, new OracleImplementation() },
4✔
37
        { DatabaseType.MicrosoftSQLServer, new MicrosoftSQLImplementation() },
4✔
38
        { DatabaseType.PostgreSql, new PostgreSqlImplementation() }
4✔
39
    };
4✔
40

41
    public static ComprehensiveQueryPerformanceCounter PerformanceCounter = null;
4✔
42

43
    /// <summary>
44
    /// Sets the default Global timeout in seconds for new DbCommand objects being created
45
    /// </summary>
46
    public static int GlobalTimeout = 30;
4✔
47

48

49
    public static IDiscoveredServerHelper For(DbConnection con)
50
    {
51
        return _dbConHelpersByType.Values.Single(i => i.IsFor(con)).GetServerHelper();
2,498,980✔
52
    }
53

54
    public static IDiscoveredServerHelper For(DbConnectionStringBuilder connectionStringBuilder)
55
    {
56
        return _dbConHelpersByType.Values.Single(i => i.IsFor(connectionStringBuilder)).GetServerHelper();
650✔
57
    }
58

59
    public static IDiscoveredServerHelper For(DatabaseType dbType) => _dbConHelpersByType[dbType].GetServerHelper();
1,098✔
60

61
    public static IDiscoveredServerHelper For(DbCommand cmd)
62
    {
63
        return cmd switch
437,184!
64
        {
437,184✔
65
            SqlCommand => _dbConHelpersByType[DatabaseType.MicrosoftSQLServer].GetServerHelper(),
416,522✔
66
            OracleCommand => _dbConHelpersByType[DatabaseType.Oracle].GetServerHelper(),
×
67
            MySqlCommand => _dbConHelpersByType[DatabaseType.MySql].GetServerHelper(),
20,662✔
68
            NpgsqlCommand => _dbConHelpersByType[DatabaseType.PostgreSql].GetServerHelper(),
×
69
            _ => throw new NotSupportedException($"Didn't know what helper to use for DbCommand Type {cmd.GetType()}")
×
70
        };
437,184✔
71
        //todo: add this method to implementation in FAnsi
72
        //return _dbConHelpersByType.Values.Single(i => i.IsFor(cmd)).GetServerHelper();
73
    }
74

75
    public static DbCommand GetCommand(string s, DbConnection con, DbTransaction transaction = null)
76
    {
77
        var cmd = For(con).GetCommand(s, con, transaction);
499,796✔
78

79
        PerformanceCounter?.AddAudit(cmd, Environment.StackTrace.ToString());
499,796✔
80

81
        cmd.CommandTimeout = GlobalTimeout;
499,796✔
82
        return cmd;
499,796✔
83
    }
84

85
    public static DbCommand GetInsertCommand(DbCommand cmd)
86
    {
87
        var toReturn = For(cmd).GetCommandBuilder(cmd).GetInsertCommand(true);
×
88
        toReturn.CommandTimeout = cmd.CommandTimeout = GlobalTimeout;
×
89

90
        return toReturn;
×
91
    }
92

93
    public static DbParameter GetParameter(string parameterName, DbCommand forCommand) =>
94
        For(forCommand).GetParameter(parameterName);
437,174✔
95

96
    public static DbParameter GetParameter(string parameterName, DatabaseType databaseType) =>
97
        For(databaseType).GetParameter(parameterName);
×
98

99
    // only used in missing fields checker, should be in UsefulStuff?
100
    public static DbConnection GetConnection(DbConnectionStringBuilder connectionStringBuilder) =>
101
        For(connectionStringBuilder).GetConnection(connectionStringBuilder);
130✔
102

103
    public static DbDataAdapter GetDataAdapter(DbCommand cmd) => For(cmd).GetDataAdapter(cmd);
10✔
104

105
    public static void AddParameterWithValueToCommand(string parameterName, DbCommand command, object valueForParameter)
106
    {
107
        var dbParameter = GetParameter(parameterName, command);
45,237✔
108
        dbParameter.Value = valueForParameter;
45,237✔
109
        command.Parameters.Add(dbParameter);
45,237✔
110
    }
45,237✔
111
}
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

© 2025 Coveralls, Inc