swift/test/unit/common/middleware
Matthew Oliver 4ce907a4ae relinker: Add /recon/relinker endpoint and drop progress stats
To further benefit the stats capturing for the relinker, drop partition
progress to a new relinker.recon recon cache and add a new recon endpoint:

  GET /recon/relinker

To gather get live relinking progress data:

  $ curl http://127.0.0.3:6030/recon/relinker |python -mjson.tool
  {
      "devices": {
          "sdb3": {
              "parts_done": 523,
              "policies": {
                  "1": {
                      "next_part_power": 11,
                      "start_time": 1618998724.845616,
                      "stats": {
                          "errors": 0,
                          "files": 1630,
                          "hash_dirs": 1630,
                          "linked": 1630,
                          "policies": 1,
                          "removed": 0
                      },
                      "timestamp": 1618998730.24672,
                      "total_parts": 1029,
                      "total_time": 5.400741815567017
                  }},
              "start_time": 1618998724.845946,
              "stats": {
                  "errors": 0,
                  "files": 836,
                  "hash_dirs": 836,
                  "linked": 836,
                  "removed": 0
              },
              "timestamp": 1618998730.24672,
              "total_parts": 523,
              "total_time": 5.400741815567017
          },
          "sdb7": {
              "parts_done": 506,
              "policies": {
                  "1": {
                      "next_part_power": 11,
                      "part_power": 10,
                      "parts_done": 506,
                      "start_time": 1618998724.845616,
                      "stats": {
                          "errors": 0,
                          "files": 794,
                          "hash_dirs": 794,
                          "linked": 794,
                          "removed": 0
                      },
                      "step": "relink",
                      "timestamp": 1618998730.166175,
                      "total_parts": 506,
                      "total_time": 5.320528984069824
                  }
              },
              "start_time": 1618998724.845616,
              "stats": {
                  "errors": 0,
                  "files": 794,
                  "hash_dirs": 794,
                  "linked": 794,
                  "removed": 0
              },
              "timestamp": 1618998730.166175,
              "total_parts": 506,
              "total_time": 5.320528984069824
          }
      },
      "workers": {
          "100": {
              "drives": ["sda1"],
              "return_code": 0,
              "timestamp": 1618998730.166175}
      }}

Also, add a constant DEFAULT_RECON_CACHE_PATH to help fix failing tests
by mocking recon_cache_path, so that errors are not logged due
to dump_recon_cache exceptions.

Mock recon_cache_path more widely and assert no error logs more
widely.

Change-Id: I625147dadd44f008a7c48eb5d6ac1c54c4c0ef05
2021-05-10 16:13:32 +01:00
..
crypto Cleanup tests' import of debug_logger 2021-04-27 12:04:41 +01:00
s3api Remove test-requirement on fixtures 2021-05-05 15:45:33 -07:00
__init__.py Initial commit of middleware refactor 2010-08-20 00:42:38 +00:00
helpers.py Cleanup tests' import of debug_logger 2021-04-27 12:04:41 +01:00
test_account_quotas.py pep8: Turn on E305 2020-04-03 21:22:38 +02:00
test_acl.py pep8 fix: assertEquals -> assertEqual 2015-10-11 12:57:25 +02:00
test_bulk.py Cleanup tests' import of debug_logger 2021-04-27 12:04:41 +01:00
test_catch_errors.py Merge "Enforce Content-Length in catch_errors" 2018-06-28 12:23:45 +00:00
test_cname_lookup.py Ensure domain stored in memcached gets utf8 decoded on py2 2020-02-11 14:42:33 -08:00
test_container_sync.py Cleanup tests' import of debug_logger 2021-04-27 12:04:41 +01:00
test_copy.py Cleanup tests' import of debug_logger 2021-04-27 12:04:41 +01:00
test_crossdomain.py Increase some middleware test coverage 2019-06-05 06:19:04 +00:00
test_dlo.py replace md5 with swift utils version 2020-12-15 09:52:55 -05:00
test_domain_remap.py swob: Fix up some WSGI string business 2018-06-27 15:55:30 -07:00
test_etag_quoter.py Middleware that allows a user to have quoted Etags 2020-01-27 12:53:35 -08:00
test_formpost.py py3: Fix formpost unicode filename issues 2020-01-15 16:52:37 -08:00
test_gatekeeper.py Allow internal clients to use reserved namespace 2019-11-27 11:22:00 -06:00
test_healthcheck.py swob: Stop auto-encoding unicode bodies 2018-06-28 09:58:44 -07:00
test_keystoneauth.py Cleanup tests' import of debug_logger 2021-04-27 12:04:41 +01:00
test_list_endpoints.py py3: Monkey-patch json.loads to accept bytes on py35 2018-11-02 21:38:53 +00:00
test_listing_formats.py Cleanup tests' import of debug_logger 2021-04-27 12:04:41 +01:00
test_memcache.py Memcached client TLS support 2021-01-06 09:47:38 -08:00
test_name_check.py pep8: Turn on E305 2020-04-03 21:22:38 +02:00
test_object_versioning.py replace md5 with swift utils version 2020-12-15 09:52:55 -05:00
test_proxy_logging.py Cleanup tests' import of debug_logger 2021-04-27 12:04:41 +01:00
test_quotas.py pep8: Turn on E305 2020-04-03 21:22:38 +02:00
test_ratelimit.py Cleanup tests' import of debug_logger 2021-04-27 12:04:41 +01:00
test_read_only.py Cleanup tests' import of debug_logger 2021-04-27 12:04:41 +01:00
test_recon.py relinker: Add /recon/relinker endpoint and drop progress stats 2021-05-10 16:13:32 +01:00
test_slo.py Use CloseableChain when creating iterator of SLO response 2020-12-29 16:14:28 +00:00
test_staticweb.py py3: port staticweb middleware 2019-04-10 17:08:21 +10:00
test_subrequest_logging.py Cleanup tests' import of debug_logger 2021-04-27 12:04:41 +01:00
test_symlink.py Log storage policy with s3api requests 2020-10-01 17:18:13 -07:00
test_tempauth.py fix not clear cause for invalid username 2021-04-22 19:45:38 +00:00
test_tempurl.py py3: Port the tempurl middleware 2019-06-20 12:41:50 -07:00
test_versioned_writes.py middlewares: Clean up app iters better 2020-02-12 21:27:15 -08:00
test_xprofile.py Consistently use io.BytesIO 2019-10-15 15:09:46 +02:00