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

pulibrary / tigerdata-app / b6e4a7c7-d411-4822-a760-84eba5096a52

01 Dec 2025 03:02PM UTC coverage: 74.875% (-12.7%) from 87.594%
b6e4a7c7-d411-4822-a760-84eba5096a52

Pull #2251

circleci

carolyncole
Updating the department select to utilize LuxInputMultiSelect
The component only allows an item to be selected once (only for non asynch results which departments are).
fiexs #2134
Pull Request #2251: Updating the department select to utilize LuxInputMultiSelect

2390 of 3192 relevant lines covered (74.87%)

215.79 hits per line

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

97.67
/app/models/mediaflux/query_request.rb
1
# frozen_string_literal: true
2
module Mediaflux
1✔
3
  class QueryRequest < Request
1✔
4
    attr_reader :aql_query, :collection, :action, :deep_search, :iterator
1✔
5

6
    # Constructor
7
    # @param session_token [String] the API token for the authenticated session
8
    # @param aql_query [String] Optional AQL query string
9
    # @param collection [Integer] Optional collection id
10
    # @param action [String] Optional, by default it uses get-name but it could also be get-meta to get all
11
    #                        the fields for the assets or `get-values` to get a limited list of fields.
12
    # @param deep_search [Bool] Optional, false by default. When true queries the collection and it subcollections.
13
    # @param iterator [Bool] Optional, true by default. When true returns an iterator.  When false returns a list of results
14
    def initialize(session_token:, aql_query: nil, collection: nil, action: "get-values", deep_search: false, iterator: true)
1✔
15
      super(session_token: session_token)
33✔
16
      @aql_query = aql_query
33✔
17
      @collection = collection
33✔
18
      @action = action
33✔
19
      @deep_search = deep_search
33✔
20
      @iterator = iterator
33✔
21
    end
22

23
    # Specifies the Mediaflux service to use when running a query
24
    # @return [String]
25
    def self.service
1✔
26
      "asset.query"
66✔
27
    end
28

29
    # Returns the iterator that could be used to fetch the data
30
    def result
1✔
31
      xml = response_xml
30✔
32
      xml.xpath("/response/reply/result/iterator").text.to_i
30✔
33
    end
34

35
    def result_items
1✔
36
      xml = response_xml
3✔
37
      xml.xpath("/response/reply/result").children.map do |node|
3✔
38
        {
39
          id: node.xpath("./@id").text,
7✔
40
          name: node.xpath("./name").text,
41
          path: node.xpath("./path").text
42
        }
43
      end
44
    end
45

46
    private
1✔
47

48
      def build_http_request_body(name:)
1✔
49
        super do |xml|
66✔
50
          xml.args do
66✔
51
            # TODO: there is a bug in mediaflux that does not allow the comented out line to paginate
52
            #      For the moment we will utilize the where clasue that does allow pagination
53
            # xml.collection collection if collection.present?
54
            if collection.present?
66✔
55
              xml.where mf_where(collection)
60✔
56
            end
57
            xml.where aql_query if aql_query.present?
66✔
58
            xml.action action if action.present?
66✔
59
            declare_get_values_fields(xml) if action == "get-values"
66✔
60
            xml.as "iterator" if iterator
66✔
61
          end
62
        end
63
      end
64

65
      def mf_where(collection)
1✔
66
        if deep_search
60✔
67
          "asset in static collection or subcollection of #{collection}"
60✔
68
        else
69
          "asset in collection #{collection}"
×
70
        end
71
      end
72

73
      # Adds the declarations to fetch specific fields
74
      def declare_get_values_fields(xml)
1✔
75
        declare_get_value_field(xml, "name", "name")
66✔
76
        declare_get_value_field(xml, "path", "path")
66✔
77
        declare_get_value_field(xml, "content/@total-size", "total-size")
66✔
78
        declare_get_value_field(xml, "mtime", "mtime")
66✔
79
        declare_get_value_field(xml, "@collection", "collection")
66✔
80
      end
81

82
      # Adds a single field declaration
83
      def declare_get_value_field(xml, field_xpath, field_name)
1✔
84
        xml.xpath do
330✔
85
          xml.parent.set_attribute("ename", field_name)
330✔
86
          xml.text(field_xpath)
330✔
87
        end
88
      end
89
  end
90
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