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

HicServices / RDMP / 6237307473

19 Sep 2023 04:02PM UTC coverage: 57.015% (-0.4%) from 57.44%
6237307473

push

github

web-flow
Feature/rc4 (#1570)

* Syntax tidying
* Dependency updates
* Event handling singletons (ThrowImmediately and co)

---------

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: James A Sutherland <>
Co-authored-by: James Friel <jfriel001@dundee.ac.uk>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

10734 of 20259 branches covered (0.0%)

Branch coverage included in aggregate %.

5922 of 5922 new or added lines in 565 files covered. (100.0%)

30687 of 52390 relevant lines covered (58.57%)

7361.8 hits per line

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

0.0
/Rdmp.Core/DataLoad/Triggers/Implementations/OracleTriggerImplementer.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.Linq;
8
using FAnsi.Discovery;
9
using FAnsi.Discovery.QuerySyntax;
10
using Oracle.ManagedDataAccess.Client;
11
using Rdmp.Core.ReusableLibraryCode.Exceptions;
12
using Rdmp.Core.ReusableLibraryCode.Settings;
13

14
namespace Rdmp.Core.DataLoad.Triggers.Implementations;
15

16
/// <inheritdoc/>
17
internal class OracleTriggerImplementer : MySqlTriggerImplementer
18
{
19
    /// <inheritdoc cref="TriggerImplementer(DiscoveredTable,bool)"/>
20
    public OracleTriggerImplementer(DiscoveredTable table, bool createDataLoadRunIDAlso = true) : base(table,
×
21
        createDataLoadRunIDAlso)
×
22
    {
23
    }
×
24

25
    protected override string GetTriggerBody()
26
    {
27
        using var con = _server.GetConnection();
×
28
        con.Open();
×
29

30
        using var cmd =
×
31
            _server.GetCommand(
×
32
                $"select trigger_body from all_triggers where trigger_name = UPPER('{GetTriggerName()}')", con);
×
33
        ((OracleCommand)cmd).InitialLONGFetchSize = -1;
×
34
        var r = cmd.ExecuteReader();
×
35

36
        while (r.Read())
×
37
            return (string)r["trigger_body"];
×
38

39
        return null;
×
40
    }
×
41

42
    protected override void AddValidFrom(DiscoveredTable table, IQuerySyntaxHelper syntaxHelper)
43
    {
44
        _table.AddColumn(SpecialFieldNames.ValidFrom, " DATE DEFAULT CURRENT_TIMESTAMP", true,
×
45
            UserSettings.ArchiveTriggerTimeout);
×
46
    }
×
47

48
    protected override string CreateTriggerBody()
49
    {
50
        var syntax = _table.GetQuerySyntaxHelper();
×
51

52
        return $@"BEGIN
×
53
    INSERT INTO {_archiveTable.GetFullyQualifiedName()} ({string.Join(",", _columns.Select(c => syntax.EnsureWrapped(c.GetRuntimeName())))},hic_validTo,hic_userID,hic_status) VALUES ({string.Join(",", _columns.Select(c => $":old.{syntax.EnsureWrapped(c.GetRuntimeName())}"))},CURRENT_DATE,USER,'U');
×
54

×
55
  :new.{syntax.EnsureWrapped(SpecialFieldNames.ValidFrom)} := sysdate;
×
56

×
57

×
58
  END";
×
59
    }
60

61
    protected override void AssertTriggerBodiesAreEqual(string sqlThen, string sqlNow)
62
    {
63
        sqlNow ??= "";
×
64
        sqlThen ??= "";
×
65

66
        if (!sqlNow.Trim(';', ' ', '\t').Equals(sqlThen.Trim(';', ' ', '\t')))
×
67
            throw new ExpectedIdenticalStringsException("Sql body for trigger doesn't match expected sql", sqlThen,
×
68
                sqlNow);
×
69
    }
×
70
}
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