コード例 #1
0
    def test_response_speed_oai(self):
        """oairepository - speed of response for oai_dc output"""
        allowed_seconds_per_record_oai = 0.02

        # Test oai ListRecords performance
        t0 = time.time()
        oai_repository_server.oailistrecords('metadataPrefix=oai_dc&verb=ListRecords')
        t = time.time() - t0
        if t > self.number_of_records * allowed_seconds_per_record_oai:
            self.fail("""Response for ListRecords with metadataPrefix=oai_dc took too much time:
%s seconds.
Limit: %s seconds""" % (t, self.number_of_records * allowed_seconds_per_record_oai))
コード例 #2
0
    def test_response_speed_marcxml(self):
        """oairepository - speed of response for marcxml output"""
        allowed_seconds_per_record_marcxml = 0.05

        # Test marcxml ListRecords performance
        t0 = time.time()
        oai_repository_server.oailistrecords('metadataPrefix=marcxml&verb=ListRecords')
        t = time.time() - t0
        if t > self.number_of_records * allowed_seconds_per_record_marcxml:
            self.fail("""Response for ListRecords with metadataPrefix=marcxml took too much time:\n
%s seconds.
Limit: %s seconds""" % (t, self.number_of_records * allowed_seconds_per_record_marcxml))
コード例 #3
0
    def test_response_speed_marcxml(self):
        """oairepository - speed of response for marcxml output"""
        allowed_seconds_per_record_marcxml = 0.05

        # Test marcxml ListRecords performance
        t0 = time.time()
        oai_repository_server.oailistrecords('metadataPrefix=marcxml&verb=ListRecords')
        t = time.time() - t0
        if t > self.number_of_records * allowed_seconds_per_record_marcxml:
            self.fail("""Response for ListRecords with metadataPrefix=marcxml took too much time:\n
%s seconds.
Limit: %s seconds""" % (t, self.number_of_records * allowed_seconds_per_record_marcxml))
コード例 #4
0
    def test_response_speed_oai(self):
        """oairepository - speed of response for oai_dc output"""
        allowed_seconds_per_record_oai = 0.02

        # Test oai ListRecords performance
        t0 = time.time()
        oai_repository_server.oailistrecords('metadataPrefix=oai_dc&verb=ListRecords')
        t = time.time() - t0
        if t > self.number_of_records * allowed_seconds_per_record_oai:
            self.fail("""Response for ListRecords with metadataPrefix=oai_dc took too much time:
%s seconds.
Limit: %s seconds""" % (t, self.number_of_records * allowed_seconds_per_record_oai))
コード例 #5
0
 def test_verbs(self):
     """oairepository - testing verbs"""
     self.assertNotEqual(None, re.search("Identify", oai_repository_server.oaiidentify("", None)))
     self.assertNotEqual(None, re.search("ListIdentifiers", oai_repository_server.oailistidentifiers("")))
     self.assertNotEqual(None, re.search("ListRecords", oai_repository_server.oailistrecords("")))
     self.assertNotEqual(None, re.search("ListMetadataFormats", oai_repository_server.oailistmetadataformats("")))
     self.assertNotEqual(None, re.search("ListSets", oai_repository_server.oailistsets("")))
     self.assertNotEqual(None, re.search("GetRecord", oai_repository_server.oaigetrecord("")))
コード例 #6
0
 def test_verbs(self):
     """oairepository - testing verbs"""
     self.assertNotEqual(None, re.search("Identify", oai_repository_server.oaiidentify("", None)))
     self.assertNotEqual(None, re.search("ListIdentifiers", oai_repository_server.oailistidentifiers("")))
     self.assertNotEqual(None, re.search("ListRecords", oai_repository_server.oailistrecords("")))
     self.assertNotEqual(None, re.search("ListMetadataFormats", oai_repository_server.oailistmetadataformats("")))
     self.assertNotEqual(None, re.search("ListSets", oai_repository_server.oailistsets("")))
     self.assertNotEqual(None, re.search("GetRecord", oai_repository_server.oaigetrecord("")))
    def __call__(self, req, form):
        "OAI repository interface"

        # Clean input arguments. The protocol specifies that an error
        # has to be returned if the same argument is specified several
        # times. Eg:
        # oai2d?verb=ListIdentifiers&metadataPrefix=marcxml&metadataPrefix=marcxml
        # So keep the arguments as list for now so that check_argd can
        # return an error if needed (check_argd also transforms these
        # lists into strings)
        argd = wash_urlargd(form, {'verb': (list, []),
                                   'metadataPrefix': (list, []),
                                   'from': (list, []),
                                   'until': (list, []),
                                   'set': (list, []),
                                   'identifier': (list, []),
                                   'resumptionToken': (list, []),
                                   })

        ## wash_urlargd(..) function cleaned everything, but also added
        ## unwanted parameters. Remove them now
        for param in argd.keys():
            if not param in form and param != 'verb':
                del argd[param]

        ## wash_urlargd(..) function also removed unknown parameters
        ## that we would like to keep in order to send back an error
        ## as required by the protocol. But we do not need that value,
        ## so set it to empty string.
        for param in form.keys():
            if param not in argd.keys():
                argd[param] = ''

        ## But still remove 'ln' parameter that was automatically added.
        if argd.has_key('ln'):
            del argd['ln']

        ## check request for OAI compliancy
        ## also transform all the list arguments into string
        oai_error = oai_repository_server.check_argd(argd)

        ## check availability (OAI requests for Identify, ListSets and
        ## ListMetadataFormats are served immediately, otherwise we
        ## shall wait for CFG_OAI_SLEEP seconds between requests):
        if os.path.exists("%s/RTdata/RTdata" % CFG_CACHEDIR) and (argd['verb'] not in ["Identify", "ListMetadataFormats", "ListSets"]):
            time_gap = int(time.time() - os.path.getmtime("%s/RTdata/RTdata" % CFG_CACHEDIR))
            if(time_gap < CFG_OAI_SLEEP):
                req.headers_out["Status-Code"] = "503"
                req.headers_out["Retry-After"] = "%d" % (CFG_OAI_SLEEP - time_gap)
                req.status = apache.HTTP_SERVICE_UNAVAILABLE
                return "Retry after %d seconds" % (CFG_OAI_SLEEP - time_gap)
        command = "touch %s/RTdata/RTdata" % CFG_CACHEDIR
        os.system(command)

        ## construct args (argd string equivalent) for the
        ## oai_repository_server business logic (later it may be good if it
        ## takes argd directly):
        args = urllib.urlencode(argd)

        ## create OAI response

        req.content_type = "text/xml"
        req.send_http_header()

        if oai_error == "":

            ## OAI Identify

            if argd['verb']   == "Identify":
                req.write(oai_repository_server.oaiidentify(args, script_url=req.uri))


            ## OAI ListSets

            elif argd['verb'] == "ListSets":
                req.write(oai_repository_server.oailistsets(args))


            ## OAI ListIdentifiers

            elif argd['verb'] == "ListIdentifiers":
                req.write(oai_repository_server.oailistidentifiers(args))


            ## OAI ListRecords

            elif argd['verb'] == "ListRecords":
                req.write(oai_repository_server.oailistrecords(args))


            ## OAI GetRecord

            elif argd['verb'] == "GetRecord":
                req.write(oai_repository_server.oaigetrecord(args))


            ## OAI ListMetadataFormats

            elif argd['verb'] == "ListMetadataFormats":
                req.write(oai_repository_server.oailistmetadataformats(args))


            ## Unknown verb

            else:
                req.write(oai_repository_server.oai_error("badVerb","Illegal OAI verb"))


        ## OAI error

        else:
            req.write(oai_repository_server.oai_header(args,""))
            req.write(oai_error)
            req.write(oai_repository_server.oai_footer(""))

        return "\n"
コード例 #8
0
    def __call__(self, req, form):
        "OAI repository interface"

        # Clean input arguments. The protocol specifies that an error
        # has to be returned if the same argument is specified several
        # times. Eg:
        # oai2d?verb=ListIdentifiers&metadataPrefix=marcxml&metadataPrefix=marcxml
        # So keep the arguments as list for now so that check_argd can
        # return an error if needed (check_argd also transforms these
        # lists into strings)
        argd = wash_urlargd(
            form, {
                'verb': (list, []),
                'metadataPrefix': (list, []),
                'from': (list, []),
                'until': (list, []),
                'set': (list, []),
                'identifier': (list, []),
                'resumptionToken': (list, []),
            })

        ## wash_urlargd(..) function cleaned everything, but also added
        ## unwanted parameters. Remove them now
        for param in argd.keys():
            if not param in form and param != 'verb':
                del argd[param]

        ## wash_urlargd(..) function also removed unknown parameters
        ## that we would like to keep in order to send back an error
        ## as required by the protocol. But we do not need that value,
        ## so set it to empty string.
        for param in form.keys():
            if param not in argd.keys():
                argd[param] = ''

        ## But still remove 'ln' parameter that was automatically added.
        if argd.has_key('ln'):
            del argd['ln']

        ## check request for OAI compliancy
        ## also transform all the list arguments into string
        oai_error = oai_repository_server.check_argd(argd)

        ## check availability (OAI requests for Identify, ListSets and
        ## ListMetadataFormats are served immediately, otherwise we
        ## shall wait for CFG_OAI_SLEEP seconds between requests):
        if os.path.exists(
                "%s/RTdata/RTdata" % CFG_CACHEDIR) and (argd['verb'] not in [
                    "Identify", "ListMetadataFormats", "ListSets"
                ]):
            time_gap = int(time.time() -
                           os.path.getmtime("%s/RTdata/RTdata" % CFG_CACHEDIR))
            if (time_gap < CFG_OAI_SLEEP):
                req.headers_out["Status-Code"] = "503"
                req.headers_out["Retry-After"] = "%d" % (CFG_OAI_SLEEP -
                                                         time_gap)
                req.status = apache.HTTP_SERVICE_UNAVAILABLE
                return "Retry after %d seconds" % (CFG_OAI_SLEEP - time_gap)
        command = "touch %s/RTdata/RTdata" % CFG_CACHEDIR
        os.system(command)

        ## construct args (argd string equivalent) for the
        ## oai_repository_server business logic (later it may be good if it
        ## takes argd directly):
        args = urllib.urlencode(argd)

        ## create OAI response

        req.content_type = "text/xml"
        req.send_http_header()

        if oai_error == "":

            ## OAI Identify

            if argd['verb'] == "Identify":
                req.write(
                    oai_repository_server.oaiidentify(args,
                                                      script_url=req.uri))

            ## OAI ListSets

            elif argd['verb'] == "ListSets":
                req.write(oai_repository_server.oailistsets(args))

            ## OAI ListIdentifiers

            elif argd['verb'] == "ListIdentifiers":
                req.write(oai_repository_server.oailistidentifiers(args))

            ## OAI ListRecords

            elif argd['verb'] == "ListRecords":
                req.write(oai_repository_server.oailistrecords(args))

            ## OAI GetRecord

            elif argd['verb'] == "GetRecord":
                req.write(oai_repository_server.oaigetrecord(args))

            ## OAI ListMetadataFormats

            elif argd['verb'] == "ListMetadataFormats":
                req.write(oai_repository_server.oailistmetadataformats(args))

            ## Unknown verb

            else:
                req.write(
                    oai_repository_server.oai_error("badVerb",
                                                    "Illegal OAI verb"))

        ## OAI error

        else:
            req.write(oai_repository_server.oai_header(args, ""))
            req.write(oai_error)
            req.write(oai_repository_server.oai_footer(""))

        return "\n"
コード例 #9
0
 def test_resumption_token(self):
     """oairepository - testing harvesting with bad resumption token"""
     # Non existing resumptionToken
     self.assert_('badResumptionToken' in oai_repository_server.oailistrecords('resumptionToken=foobar&verb=ListRecords'))