• 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

82.86
/Rdmp.Core/DataExport/DataExtraction/FileOutputFormats/CSVOutputFormat.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.Data;
9
using System.IO;
10
using System.Linq;
11
using System.Text;
12
using System.Text.RegularExpressions;
13

14
namespace Rdmp.Core.DataExport.DataExtraction.FileOutputFormats;
15

16
/// <summary>
17
/// Helper class for writing data to CSV files.  This is a simplified version of Rfc4180Writer in that it simply strips out all problem fields rather
18
/// than applying proper escaping etc.  This is done because some researcher end point tools / scripts do not support the full specification of CSV and
19
/// it is easier to provide them with a file where problem symbols are not present than explain that they have to join multiple lines together when it is
20
/// bounded by quotes.
21
/// </summary>
22
public class CSVOutputFormat : FileOutputFormat
23
{
24
    public string Separator { get; set; }
50,668✔
25
    public string DateFormat { get; set; }
47,280✔
26

27
    public int SeparatorsStrippedOut { get; private set; }
94,368✔
28
    private static readonly string[] ThingsToStripOut = { "\r", "\n", "\t", "\"" };
2✔
29
    private StreamWriter _sw;
30
    private StringBuilder _sbWriteOutLinesBuffer;
31
    private const string _illegalCharactersReplacement = " ";
32

33
    public CSVOutputFormat(string outputFilename, string separator, string dateFormat) : base(outputFilename)
96✔
34
    {
35
        Separator = separator;
96✔
36
        DateFormat = dateFormat;
96✔
37
    }
96✔
38

39
    public override string GetFileExtension() => ".csv";
×
40

41
    public override void Open()
42
    {
43
        _sw = new StreamWriter(OutputFilename);
×
44
        _sbWriteOutLinesBuffer = new StringBuilder();
×
45
    }
×
46

47
    public override void Open(bool append)
48
    {
49
        _sw = new StreamWriter(OutputFilename, append);
46✔
50
        _sbWriteOutLinesBuffer = new StringBuilder();
46✔
51
    }
46✔
52

53
    public override void WriteHeaders(DataTable t)
54
    {
55
        //write headers separated by separator
56
        _sw.Write(string.Join(Separator, t.Columns.Cast<DataColumn>().Select(c => c.ColumnName).ToArray()));
418✔
57

58
        _sw.WriteLine();
46✔
59
    }
46✔
60

61
    public override void Append(DataRow r)
62
    {
63
        //write headers separated by separator
64
        _sbWriteOutLinesBuffer.Append(string.Join(Separator, r.ItemArray.Select(CleanString)));
3,342✔
65

66
        //write the new line
67
        _sbWriteOutLinesBuffer.Append(Environment.NewLine);
3,342✔
68
    }
3,342✔
69

70
    public override void Flush()
71
    {
72
        _sw.Write(_sbWriteOutLinesBuffer.ToString());
46✔
73
        _sbWriteOutLinesBuffer.Clear();
46✔
74
        _sw.Flush();
46✔
75
    }
46✔
76

77
    public override void Close()
78
    {
79
        _sw?.Flush();
46!
80
        _sw?.Close();
46!
81
        _sw?.Dispose();
46!
82
    }
46✔
83

84
    public string CleanString(object o)
85
    {
86
        var toReturn = CleanString(o, Separator, out var numberOfSeparatorsStrippedOutThisPass, DateFormat,
47,184✔
87
            RoundFloatsTo);
47,184✔
88

89
        SeparatorsStrippedOut += numberOfSeparatorsStrippedOutThisPass;
47,184✔
90

91
        return toReturn;
47,184✔
92
    }
93

94

95
    public static string CleanString(object o, string separator, out int separatorsStrippedOut, string dateFormat,
96
        int? roundFloatsTo)
97
    {
98
        if (o is DateTime dateTime)
47,184✔
99
        {
100
            separatorsStrippedOut = 0;
6,636✔
101
            return dateTime.ToString(dateFormat);
6,636✔
102
        }
103

104
        if (roundFloatsTo.HasValue)
40,548✔
105
        {
106
            separatorsStrippedOut = 0;
4!
107
            switch (o)
108
            {
109
                case float f: return f.ToString($"N{roundFloatsTo.Value}");
×
110
                case decimal dec: return dec.ToString($"N{roundFloatsTo.Value}");
4✔
111
                case double d: return d.ToString($"N{roundFloatsTo.Value}");
×
112
            }
113
        }
114

115
        //in order to kep a count
116
        var regexReplace = new Regex(Regex.Escape(separator));
40,544✔
117

118
        separatorsStrippedOut = 0;
40,544✔
119

120
        while (o.ToString().Contains(separator))
40,792✔
121
        {
122
            o = regexReplace.Replace(o.ToString(), _illegalCharactersReplacement, 1);
248✔
123
            separatorsStrippedOut++;
248✔
124
        }
125

126
        return o is string s
40,544✔
127
            ? ThingsToStripOut.Aggregate(s,
40,544✔
128
                (current, cToStripOut) => current.Replace(cToStripOut, _illegalCharactersReplacement)).Trim()
94,248✔
129
            : o.ToString().Trim();
40,544✔
130
    }
131
}
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