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

pulibrary / tigerdata-app / df5c5773-2d28-4ed4-a37f-15a25fbf5642

03 Nov 2025 07:09PM UTC coverage: 91.405% (+0.005%) from 91.4%
df5c5773-2d28-4ed4-a37f-15a25fbf5642

push

circleci

carolyncole
Remove the duplicate UID from the new project wizard screens
refs #2113

3 of 3 new or added lines in 1 file covered. (100.0%)

1026 existing lines in 51 files now uncovered.

2829 of 3095 relevant lines covered (91.41%)

489.18 hits per line

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

97.37
/app/presenters/project_show_presenter.rb
1
# frozen_string_literal: true
2
class ProjectShowPresenter
5✔
3
  delegate "id", "in_mediaflux?", "mediaflux_id", "status", to: :project
5✔
4
  delegate "project_id", "storage_performance_expectations", to: :project_metadata
5✔
5

6
  attr_reader :project, :project_metadata
5✔
7

8
  # @return [Class] The presenter class for building XML Documents from Projects
9
  def self.xml_presenter_class
5✔
10
    ProjectXmlPresenter
9✔
11
  end
12

13
  # While we are transitioning to fetching the data straight from Mediaflux `project` can be
14
  # an ActiveRecord Project model (when used from the Project show page) or a Hash with the
15
  # data from Mediaflux (when used from the Dashboard).
16
  # This branching can be refactored (elimitated?) once we implement ticket
17
  # https://github.com/pulibrary/tigerdata-app/issues/2039 and the project data will always
18
  # come from Mediaflux.
19
  def initialize(project)
5✔
20
    if project.is_a?(Hash)
901✔
21
      @project_mf = project
827✔
22
      @project = rails_project(@project_mf)
827✔
23
    else
24
      @project_mf = nil
74✔
25
      @project = project
74✔
26
    end
27
    @project_metadata = @project&.metadata_model
901✔
28
  end
29

30
  def title
5✔
UNCOV
31
    if @project_mf.nil?
201✔
UNCOV
32
      @project.title
49✔
33
    else
34
      @project_mf[:title]
152✔
35
    end
36
  end
37

38
  def description
5✔
UNCOV
39
    if @project_mf.nil?
49✔
UNCOV
40
      @project.metadata_model.description
49✔
41
    else
42
      @project_mf[:description]
×
43
    end
44
  end
45

46
  # @return [String] the XML for the project Document
47
  def to_xml
5✔
48
    xml_document.to_xml
8✔
49
  end
50

51
  # @return [Nokogiri::XML::Document] the XML Document for the Project
52
  def xml_document
5✔
53
    @xml_document ||= xml_presenter.document
9✔
54
  end
55

56
  def created
5✔
UNCOV
57
    @project.created_at.strftime("%b %e, %Y %l:%M %p")
35✔
58
  end
59

60
  def updated
5✔
UNCOV
61
    @project.updated_at.strftime("%b %e, %Y %l:%M %p")
35✔
62
  end
63

64
  def data_sponsor
5✔
UNCOV
65
    if @project_mf.nil?
190✔
UNCOV
66
      User.find_by(uid: @project.metadata["data_sponsor"]).uid
35✔
67
    else
68
      User.find_by(uid: @project_mf[:data_sponsor])&.uid
155✔
69
    end
70
  end
71

72
  def data_manager
5✔
UNCOV
73
    if @project_mf.nil?
109✔
UNCOV
74
      User.find_by(uid: @project.metadata["data_manager"]).uid
35✔
75
    else
76
      User.find_by(uid: @project_mf[:data_manager])&.uid
74✔
77
    end
78
  end
79

80
  def project_purpose
5✔
UNCOV
81
    if @project_mf.nil?
2✔
UNCOV
82
      project_metadata.project_purpose
2✔
83
    else
84
      @project_mf[:project_purpose]
×
85
    end
86
  end
87

88
  # used to hide the project root that is not visible to the end user
89
  def project_directory
5✔
UNCOV
90
    project.project_directory.gsub(Mediaflux::Connection.hidden_root, "")
14✔
91
  end
92

93
  def storage_capacity(session_id: nil)
5✔
UNCOV
94
    return project_metadata.storage_capacity if session_id.nil?
37✔
95

UNCOV
96
    persisted = project.storage_capacity_raw(session_id: session_id)
35✔
UNCOV
97
    value = persisted.to_f
35✔
98

UNCOV
99
    value*default_capacity_divisor
35✔
100
  end
101

102
  def formatted_storage_capacity(session_id:)
5✔
UNCOV
103
    value = storage_capacity(session_id: session_id)
35✔
UNCOV
104
    format("%.3f", value)
35✔
105
  end
106

107
  def formatted_quota_percentage(session_id:)
5✔
UNCOV
108
    value = quota_percentage(session_id:)
35✔
UNCOV
109
    format("%.3f", value)
35✔
110
  end
111

112
  def quota_usage(session_id:)
5✔
UNCOV
113
    "#{project.storage_usage(session_id:)} out of #{project.storage_capacity(session_id:)} used"
187✔
114
  end
115

116
  def quota_percentage(session_id:)
5✔
UNCOV
117
    storage_capacity = project.storage_capacity_raw(session_id:)
146✔
UNCOV
118
    return 0 if storage_capacity.zero?
146✔
119

120
    storage_usage = project.storage_usage_raw(session_id:)
130✔
121
    (storage_usage.to_f / storage_capacity.to_f) * 100
130✔
122
  end
123

124
  def project_in_rails?
5✔
125
    project != nil
827✔
126
  end
127

128
  private
5✔
129

130
    # Capacity is in bytes
131
    def default_capacity_divisor
5✔
UNCOV
132
      1.0/(1000.0**3)
35✔
133
    end
134

135
    def xml_presenter_args
5✔
136
      project
9✔
137
    end
138

139
    def xml_presenter
5✔
140
      @xml_presenter ||= self.class.xml_presenter_class.new(xml_presenter_args)
9✔
141
    end
142

143
    def rails_project(project_mf)
5✔
144
      database_record = Project.where(mediaflux_id:project_mf[:mediaflux_id]).first
827✔
145
      if database_record.nil?
827✔
146
        Rails.logger.warn("Mediaflux project with ID #{project_mf[:mediaflux_id]} is not in the Rails database (title: #{project_mf[:title]})")
738✔
147
        Honeybadger.notify("Mediaflux project with ID #{project_mf[:mediaflux_id]} is not in the Rails database (title: #{project_mf[:title]})")
738✔
148
      end
149
      database_record
827✔
150
    end
151
end
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