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

pulibrary / tigerdata-app / 6588ad4d-e242-4902-a1a0-b1458c34681f

27 Oct 2025 06:00PM UTC coverage: 91.33% (+0.005%) from 91.325%
6588ad4d-e242-4902-a1a0-b1458c34681f

Pull #2057

circleci

web-flow
Merge branch 'main' into 2037-dashboard-mf
Pull Request #2057: Dashboard displays projects straights from Mediaflux

52 of 69 new or added lines in 4 files covered. (75.36%)

571 existing lines in 36 files now uncovered.

2802 of 3068 relevant lines covered (91.33%)

486.93 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)
1,621✔
NEW
21
      @project_mf = project
1,547✔
NEW
22
      @project = rails_project(@project_mf)
1,547✔
23
    else
24
      @project_mf = nil
74✔
25
      @project = project
74✔
26
    end
27
    @project_metadata = @project&.metadata_model
1,621✔
28
  end
29

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

38
  def description
5✔
39
    if @project_mf.nil?
49✔
40
      @project.metadata_model.description
49✔
41
    else
NEW
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✔
57
    @project.created_at.strftime("%b %e, %Y %l:%M %p")
35✔
58
  end
59

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

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

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

80
  def project_purpose
5✔
81
    if @project_mf.nil?
2✔
82
      project_metadata.project_purpose
2✔
83
    else
NEW
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✔
90
    project.project_directory.gsub(Mediaflux::Connection.hidden_root, "")
14✔
91
  end
92

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

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

99
    value*default_capacity_divisor
35✔
100
  end
101

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

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

112
  def quota_usage(session_id:)
5✔
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✔
117
    storage_capacity = project.storage_capacity_raw(session_id:)
146✔
118
    return 0 if storage_capacity.zero?
146✔
119

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

124
  def project_in_rails?
5✔
NEW
125
    project != nil
1,547✔
126
  end
127

128
  private
5✔
129

130
    # Capacity is in bytes
131
    def default_capacity_divisor
5✔
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✔
NEW
144
      database_record = Project.where(mediaflux_id:project_mf[:mediaflux_id]).first
1,547✔
NEW
145
      if database_record.nil?
1,547✔
NEW
146
        Rails.logger.warn("Mediaflux project with ID #{project_mf[:mediaflux_id]} is not in the Rails database (title: #{project_mf[:title]})")
1,458✔
NEW
147
        Honeybadger.notify("Mediaflux project with ID #{project_mf[:mediaflux_id]} is not in the Rails database (title: #{project_mf[:title]})")
1,458✔
148
      end
NEW
149
      database_record
1,547✔
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