• 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

44.44
/Rdmp.Core/QueryBuilding/AggregateCountColumn.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 FAnsi.Discovery.QuerySyntax;
8
using Rdmp.Core.Curation.Data;
9
using Rdmp.Core.Curation.Data.Spontaneous;
10
using Rdmp.Core.MapsDirectlyToDatabaseTable;
11
using Rdmp.Core.MapsDirectlyToDatabaseTable.Attributes;
12
using Rdmp.Core.QueryBuilding.SyntaxChecking;
13
using Rdmp.Core.ReusableLibraryCode.Checks;
14

15
namespace Rdmp.Core.QueryBuilding;
16

17
/// <summary>
18
/// The count(*) column in an AggregateConfiguration, this is used by AggregateBuilder.  This can be any aggregate function such as 'sum', 'avg' etc.
19
/// </summary>
20
public class AggregateCountColumn : SpontaneousObject, IColumn
21
{
22
    private IQuerySyntaxHelper _syntaxHelper;
23
    private readonly string _sql;
24

25
    /// <summary>
26
    /// The default alias for unamed count columns
27
    /// </summary>
28
    public const string DefaultAliasName = "MyCount";
29

30
    /// <summary>
31
    /// Creates a new Aggregate Function (count / max etc) with the given line of SELECT SQL
32
    /// <para>Can include aliases e.g. count(*) as MyCount</para>
33
    /// </summary>
34
    /// <param name="sql"></param>
35
    public AggregateCountColumn(string sql) : base(new MemoryRepository())
654✔
36
    {
37
        _sql = sql;
654✔
38
    }
654✔
39

40
    /// <summary>
41
    /// Initializes the <see cref="IQuerySyntaxHelper"/> for the column and optionally ensures that it has an alias.  If no <see cref="Alias"/> has
42
    /// been specified or was found in the current sql then <see cref="DefaultAliasName"/> is set.
43
    /// </summary>
44
    /// <param name="syntaxHelper"></param>
45
    /// <param name="ensureAliasExists"></param>
46
    public void SetQuerySyntaxHelper(IQuerySyntaxHelper syntaxHelper, bool ensureAliasExists)
47
    {
48
        _syntaxHelper = syntaxHelper;
670✔
49

50
        //if alias exists
51
        if (_syntaxHelper.SplitLineIntoSelectSQLAndAlias(_sql, out var select, out var alias))
670!
52
            Alias = alias; //use the users explicit alias
×
53
        else
54
            Alias = ensureAliasExists ? DefaultAliasName : null; //set an alias of MyCount
670✔
55

56
        SelectSQL = select;
670✔
57
    }
670✔
58

59
    /// <inheritdoc/>
60
    public string GetRuntimeName() =>
61
        _syntaxHelper == null
×
62
            ? throw new System.Exception("SyntaxHelper is null, call SetQuerySyntaxHelper first")
×
63
            : string.IsNullOrWhiteSpace(Alias)
×
64
                ? _syntaxHelper.GetRuntimeName(SelectSQL)
×
65
                : Alias;
×
66

67
    /// <summary>
68
    /// Combines the <see cref="SelectSQL"/> with the <see cref="Alias"/> for use in SELECT Sql
69
    /// </summary>
70
    /// <returns></returns>
71
    public string GetFullSelectLineStringForSavingIntoAnAggregate() => string.IsNullOrWhiteSpace(Alias)
×
72
        ? SelectSQL
×
73
        : SelectSQL + _syntaxHelper.AliasPrefix + Alias;
×
74

75
    /// <inheritdoc/>
76
    public ColumnInfo ColumnInfo => null;
644✔
77

78
    /// <inheritdoc/>
79
    public int Order { get; set; }
1,514✔
80

81
    /// <inheritdoc/>
82
    [Sql]
83
    public string SelectSQL { get; set; }
1,360✔
84

85
    /// <inheritdoc/>
86
    public string Alias { get; private set; }
1,508✔
87

88
    /// <inheritdoc/>
89
    public bool HashOnDataRelease => false;
660✔
90

91
    /// <inheritdoc/>
92
    public bool IsExtractionIdentifier => false;
×
93

94
    /// <inheritdoc/>
95
    public bool IsPrimaryKey => false;
×
96

97
    /// <inheritdoc/>
98
    public void Check(ICheckNotifier notifier)
99
    {
100
        new ColumnSyntaxChecker(this).Check(notifier);
×
101
    }
×
102
}
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