)]}'
{"id":"openstack%2Fceilometer~962876","triplet_id":"openstack%2Fceilometer~master~I922e3861c30ba974714179c9144b770fb303260b","project":"openstack/ceilometer","branch":"master","attention_set":{},"removed_from_attention_set":{"9816":{"account":{"_account_id":9816,"name":"Takashi Kajinami","email":"kajinamit@oss.nttdata.com","username":"kajinamit"},"last_update":"2025-10-13 13:02:48.000000000","reason":"Change was submitted"},"4264":{"account":{"_account_id":4264,"name":"Matthias Runge","email":"mrunge@redhat.com","username":"mrunge"},"last_update":"2025-10-07 07:46:44.000000000","reason":"removed on reply"},"13177":{"account":{"_account_id":13177,"name":"Emma Foley","email":"efoley@redhat.com","username":"emma-l-foley"},"last_update":"2025-10-13 13:02:48.000000000","reason":"Change was submitted"}},"hashtags":[],"change_id":"I922e3861c30ba974714179c9144b770fb303260b","subject":"Remove libvirt dependency from test_discovery","status":"MERGED","created":"2025-10-02 20:13:18.000000000","updated":"2025-10-13 13:03:43.000000000","submitted":"2025-10-13 13:02:48.000000000","submitter":{"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]},"total_comment_count":3,"unresolved_comment_count":0,"has_review_started":true,"submission_id":"962876","meta_rev_id":"392aed2098cba9d114dc3a9af3b8f1ab0b153bc0","_number":962876,"virtual_id_number":962876,"owner":{"_account_id":13177,"name":"Emma Foley","email":"efoley@redhat.com","username":"emma-l-foley"},"actions":{},"labels":{"Verified":{"approved":{"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]},"all":[{"tag":"autogenerated:zuul:gate","value":2,"date":"2025-10-13 13:02:48.000000000","permitted_voting_range":{"min":2,"max":2},"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]},{"value":0,"_account_id":34975,"name":"Jaromír Wysoglad","email":"jwysogla@redhat.com","username":"jwysogla"},{"value":0,"_account_id":4264,"name":"Matthias Runge","email":"mrunge@redhat.com","username":"mrunge"}],"values":{"-2":"Fails","-1":"Doesn\u0027t seem to work"," 0":"No score","+1":"Works for me","+2":"Verified"},"description":"","default_value":0,"optional":true},"Code-Review":{"approved":{"_account_id":34975,"name":"Jaromír Wysoglad","email":"jwysogla@redhat.com","username":"jwysogla"},"all":[{"value":0,"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]},{"value":2,"date":"2025-10-13 12:39:07.000000000","permitted_voting_range":{"min":2,"max":2},"_account_id":34975,"name":"Jaromír Wysoglad","email":"jwysogla@redhat.com","username":"jwysogla"},{"value":2,"date":"2025-10-07 07:46:44.000000000","permitted_voting_range":{"min":2,"max":2},"_account_id":4264,"name":"Matthias Runge","email":"mrunge@redhat.com","username":"mrunge"}],"values":{"-2":"Do not merge","-1":"This patch needs further work before it can be merged"," 0":"No score","+1":"Looks good to me, but someone else must approve","+2":"Looks good to me (core reviewer)"},"description":"","default_value":0,"optional":true},"Workflow":{"approved":{"_account_id":34975,"name":"Jaromír Wysoglad","email":"jwysogla@redhat.com","username":"jwysogla"},"all":[{"value":0,"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]},{"value":1,"date":"2025-10-13 12:39:07.000000000","permitted_voting_range":{"min":1,"max":1},"_account_id":34975,"name":"Jaromír Wysoglad","email":"jwysogla@redhat.com","username":"jwysogla"},{"value":0,"_account_id":4264,"name":"Matthias Runge","email":"mrunge@redhat.com","username":"mrunge"}],"values":{"-1":"Work in progress"," 0":"Ready for reviews","+1":"Approved"},"description":"","default_value":0,"optional":true}},"removable_reviewers":[{"_account_id":9816,"name":"Takashi Kajinami","email":"kajinamit@oss.nttdata.com","username":"kajinamit"}],"reviewers":{"REVIEWER":[{"_account_id":4264,"name":"Matthias Runge","email":"mrunge@redhat.com","username":"mrunge"},{"_account_id":9816,"name":"Takashi Kajinami","email":"kajinamit@oss.nttdata.com","username":"kajinamit"},{"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]},{"_account_id":34975,"name":"Jaromír Wysoglad","email":"jwysogla@redhat.com","username":"jwysogla"}]},"pending_reviewers":{},"reviewer_updates":[{"updated":"2025-10-02 20:28:46.000000000","updated_by":{"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]},"reviewer":{"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]},"state":"REVIEWER"},{"updated":"2025-10-06 14:00:08.000000000","updated_by":{"_account_id":13177,"name":"Emma Foley","email":"efoley@redhat.com","username":"emma-l-foley"},"reviewer":{"_account_id":9816,"name":"Takashi Kajinami","email":"kajinamit@oss.nttdata.com","username":"kajinamit"},"state":"REVIEWER"},{"updated":"2025-10-06 14:00:08.000000000","updated_by":{"_account_id":13177,"name":"Emma Foley","email":"efoley@redhat.com","username":"emma-l-foley"},"reviewer":{"_account_id":4264,"name":"Matthias Runge","email":"mrunge@redhat.com","username":"mrunge"},"state":"REVIEWER"},{"updated":"2025-10-13 12:39:07.000000000","updated_by":{"_account_id":34975,"name":"Jaromír Wysoglad","email":"jwysogla@redhat.com","username":"jwysogla"},"reviewer":{"_account_id":34975,"name":"Jaromír Wysoglad","email":"jwysogla@redhat.com","username":"jwysogla"},"state":"REVIEWER"}],"messages":[{"id":"d79676f1491f0608fd295bbc88440b6be6d0f5fd","tag":"autogenerated:gerrit:newPatchSet","author":{"_account_id":13177,"name":"Emma Foley","email":"efoley@redhat.com","username":"emma-l-foley"},"date":"2025-10-02 20:13:18.000000000","message":"Uploaded patch set 1.","accounts_in_message":[],"_revision_number":1},{"id":"af1f27387557faa58e3400f8a7ffa40e4e1c828d","tag":"autogenerated:zuul:check","author":{"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]},"date":"2025-10-02 20:28:46.000000000","message":"Patch Set 1: Verified-1\n\n(2 comments)\n\nBuild failed (check pipeline).  For information on how to proceed, see\nhttps://docs.opendev.org/opendev/infra-manual/latest/developers.html#automated-testing\nand https://docs.openstack.org/project-team-guide/testing.html#how-to-handle-test-failures\n\nhttps://zuul.opendev.org/t/openstack/buildset/b994e13e41d441a987cff04389a781ef\n\n- openstack-tox-cover https://zuul.opendev.org/t/openstack/build/1a4a12e641ed4131ae1bd448d915710a : SUCCESS in 4m 47s\n- openstack-tox-pep8 https://zuul.opendev.org/t/openstack/build/9f6f865b0cac4b0fb92dad8305d93aac : FAILURE in 2m 14s\n- openstack-tox-py310 https://zuul.opendev.org/t/openstack/build/10a2c15e1d104aeb9abc167295af120d : SUCCESS in 3m 08s\n- openstack-tox-py312 https://zuul.opendev.org/t/openstack/build/03614d0400614d0cb586a9997b425523 : SUCCESS in 3m 31s\n- openstack-tox-py313 https://zuul.opendev.org/t/openstack/build/0033cb7a59e0473db50980059ec1e88e : SUCCESS in 5m 54s (non-voting)\n- openstack-tox-docs https://zuul.opendev.org/t/openstack/build/22d29a72145f4214b6036e715f2a4ae2 : SUCCESS in 6m 55s\n- build-openstack-releasenotes https://zuul.opendev.org/t/openstack/build/45c97d82a1634f519f4be64d59460a2d : SUCCESS in 5m 01s\n- requirements-check https://zuul.opendev.org/t/openstack/build/8766c4c66a0a40029e7ca21889d9b16e : SUCCESS in 1m 42s","accounts_in_message":[],"_revision_number":1},{"id":"dc794162827d3d765cfcb4d4f04c2496674f11b5","tag":"autogenerated:gerrit:newPatchSet","author":{"_account_id":13177,"name":"Emma Foley","email":"efoley@redhat.com","username":"emma-l-foley"},"date":"2025-10-06 11:48:13.000000000","message":"Uploaded patch set 2.\n\nOutdated Votes:\n* Verified-1\n","accounts_in_message":[],"_revision_number":2},{"id":"3173d3828c73aec870892d0c85c61e9f2be68f22","tag":"autogenerated:zuul:check","author":{"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]},"date":"2025-10-06 11:59:31.000000000","message":"Patch Set 2: Verified+1\n\nBuild succeeded (check pipeline).\nhttps://zuul.opendev.org/t/openstack/buildset/e85f9207f8d44e79ac4e7902951842b6\n\n- openstack-tox-cover https://zuul.opendev.org/t/openstack/build/7fd2907bf7284232934aa218b37bf5b1 : SUCCESS in 5m 06s\n- openstack-tox-pep8 https://zuul.opendev.org/t/openstack/build/79f8d08a7d4845f39a79a0fa70ab40bf : SUCCESS in 2m 53s\n- openstack-tox-py310 https://zuul.opendev.org/t/openstack/build/8e26e450baa64205b0fa7d8c60fe67cb : SUCCESS in 3m 29s\n- openstack-tox-py312 https://zuul.opendev.org/t/openstack/build/5c1c411f77ac478c8b4c58168b0acef6 : SUCCESS in 4m 21s\n- openstack-tox-py313 https://zuul.opendev.org/t/openstack/build/a934a3bc7e67401e937839ba3f2d956b : SUCCESS in 6m 53s (non-voting)\n- openstack-tox-docs https://zuul.opendev.org/t/openstack/build/c9fa58b3e2a3430386032699fb6038dc : SUCCESS in 7m 13s\n- build-openstack-releasenotes https://zuul.opendev.org/t/openstack/build/a6fa84b720a242978c9c86755845ceb6 : SUCCESS in 2m 51s\n- requirements-check https://zuul.opendev.org/t/openstack/build/0a388aeecebf4521a042998200bca1c7 : SUCCESS in 2m 16s","accounts_in_message":[],"_revision_number":2},{"id":"d2f87bacd5d273d3c7d49303792ccadd7c5a063f","author":{"_account_id":4264,"name":"Matthias Runge","email":"mrunge@redhat.com","username":"mrunge"},"date":"2025-10-07 07:46:44.000000000","message":"Patch Set 2: Code-Review+2","accounts_in_message":[],"_revision_number":2},{"id":"421e604f6580ed8af1d820be4cdb3e7efefdcec6","author":{"_account_id":4264,"name":"Matthias Runge","email":"mrunge@redhat.com","username":"mrunge"},"date":"2025-10-07 07:46:52.000000000","message":"Patch Set 2:\n\n(1 comment)","accounts_in_message":[],"_revision_number":2},{"id":"145d39425fc42f0d3def1f57e99d8b04b8ac4f69","author":{"_account_id":34975,"name":"Jaromír Wysoglad","email":"jwysogla@redhat.com","username":"jwysogla"},"date":"2025-10-13 12:39:07.000000000","message":"Patch Set 2: Code-Review+2 Workflow+1","accounts_in_message":[],"_revision_number":2},{"id":"371ad9db149eff8f0318f3983e38c0085e425b13","tag":"autogenerated:zuul:gate","author":{"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]},"date":"2025-10-13 12:39:30.000000000","message":"Patch Set 2: -Verified\n\nStarting gate jobs.","accounts_in_message":[],"_revision_number":2},{"id":"96d5e48a99329b2b5aef9b3a723f86a76345eae1","tag":"autogenerated:zuul:gate","author":{"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]},"date":"2025-10-13 13:02:48.000000000","message":"Patch Set 2: Verified+2\n\nBuild succeeded (gate pipeline).\nhttps://zuul.opendev.org/t/openstack/buildset/b9df3decd3974bfbb1fe2c04c376f80e\n\n- openstack-tox-pep8 https://zuul.opendev.org/t/openstack/build/967c06458a8c4c6497ac13bdf941426e : SUCCESS in 3m 39s\n- openstack-tox-py310 https://zuul.opendev.org/t/openstack/build/e5902c6fcb594e7ea7998fa48b7ac86d : SUCCESS in 2m 34s\n- openstack-tox-py312 https://zuul.opendev.org/t/openstack/build/879f55f8964b4ecb8919fc95dc3922ec : SUCCESS in 4m 22s\n- openstack-tox-docs https://zuul.opendev.org/t/openstack/build/51f2d8fdeb61450a8c7e32db8a9985c1 : SUCCESS in 8m 35s\n- build-openstack-releasenotes https://zuul.opendev.org/t/openstack/build/96f26bc7de0b408d9e81c903b05e5d44 : SUCCESS in 4m 57s\n- requirements-check https://zuul.opendev.org/t/openstack/build/f85e36cd91cc49198d672b2930624c06 : SUCCESS in 3m 27s","accounts_in_message":[],"_revision_number":2},{"id":"24448c8b4fcd4eac7967552a39430a0fd7a16c4b","tag":"autogenerated:gerrit:merged","author":{"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]},"date":"2025-10-13 13:02:48.000000000","message":"Change has been successfully merged","accounts_in_message":[],"_revision_number":2},{"id":"392aed2098cba9d114dc3a9af3b8f1ab0b153bc0","tag":"autogenerated:zuul:promote","author":{"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]},"date":"2025-10-13 13:03:43.000000000","message":"Patch Set 2:\n\nBuild succeeded (promote pipeline).\nhttps://zuul.opendev.org/t/openstack/buildset/66355967915a462bbc9b0481cd36a283\n\n- promote-openstack-tox-docs https://zuul.opendev.org/t/openstack/build/ba386a86a5d841bb80a0296b4a9fcb7f : SUCCESS in 43s\n- promote-openstack-releasenotes https://zuul.opendev.org/t/openstack/build/59d2ce6c127b447ea4f53750ed4d8d64 : SUCCESS in 40s","accounts_in_message":[],"_revision_number":2}],"current_revision_number":2,"current_revision":"426ab555d27bd7316c3c6b2e798393e77c632c01","revisions":{"5b971047ad2b9d953cb4c88b5a736b007f5c1d26":{"kind":"REWORK","_number":1,"created":"2025-10-02 20:13:18.000000000","uploader":{"_account_id":13177,"name":"Emma Foley","email":"efoley@redhat.com","username":"emma-l-foley"},"ref":"refs/changes/76/962876/1","fetch":{"anonymous http":{"url":"https://review.opendev.org/openstack/ceilometer","ref":"refs/changes/76/962876/1","commands":{"Checkout":"git fetch https://review.opendev.org/openstack/ceilometer refs/changes/76/962876/1 \u0026\u0026 git checkout FETCH_HEAD","Cherry Pick":"git fetch https://review.opendev.org/openstack/ceilometer refs/changes/76/962876/1 \u0026\u0026 git cherry-pick FETCH_HEAD","Format Patch":"git fetch https://review.opendev.org/openstack/ceilometer refs/changes/76/962876/1 \u0026\u0026 git format-patch -1 --stdout FETCH_HEAD","Pull":"git pull https://review.opendev.org/openstack/ceilometer refs/changes/76/962876/1"}}},"commit":{"parents":[{"commit":"42a3dbb9e94f3f199556794d7660e24935156494","subject":"Merge \"Remove outdated options from local.conf sample\"","web_links":[{"name":"gitea","tooltip":"Open in GitWeb","url":"https://opendev.org/openstack/ceilometer/commit/42a3dbb9e94f3f199556794d7660e24935156494"}]}],"author":{"name":"Emma Foley","email":"efoley@redhat.com","date":"2025-10-02 16:42:54.000000000","tz":-240},"committer":{"name":"Emma Foley","email":"efoley@redhat.com","date":"2025-10-02 20:13:02.000000000","tz":-240},"subject":"Remove libvirt dependency from test_discovery","message":"Remove libvirt dependency from test_discovery\n\nThe test_discovery module only used libvirt for a single exception\nclass (libvirtError) and one constant (VIR_ERR_NO_DOMAIN_METADATA)\nin one test method. This made libvirt-python a heavy and\nunnecessary test dependency.\n\nReplace libvirt.libvirtError with FakeLibvirtError, a lightweight\nmock exception class that implements the same get_error_code()\ninterface. Define VIR_ERR_NO_DOMAIN_METADATA locally with value\n80 as documented in libvirt API documentation. Simplify the\nFakeManualInstanceDomain.metadata() method to directly raise the\nexception with the error code passed to the constructor.\n\nRemove libvirt-python from test-requirements.txt as it is no\nlonger needed by this test module.\n\nGenerated-By: claude-code\nChange-Id: I922e3861c30ba974714179c9144b770fb303260b\nSigned-off-by: Emma Foley \u003cefoley@redhat.com\u003e\n","web_links":[{"name":"gitea","tooltip":"Open in GitWeb","url":"https://opendev.org/openstack/ceilometer/commit/5b971047ad2b9d953cb4c88b5a736b007f5c1d26"}],"resolve_conflicts_web_links":[{"name":"gitea","tooltip":"Open in GitWeb","url":"https://opendev.org/openstack/ceilometer/commit/5b971047ad2b9d953cb4c88b5a736b007f5c1d26"}]},"branch":"refs/heads/master"},"426ab555d27bd7316c3c6b2e798393e77c632c01":{"kind":"REWORK","_number":2,"created":"2025-10-06 11:48:13.000000000","uploader":{"_account_id":13177,"name":"Emma Foley","email":"efoley@redhat.com","username":"emma-l-foley"},"ref":"refs/changes/76/962876/2","fetch":{"anonymous http":{"url":"https://review.opendev.org/openstack/ceilometer","ref":"refs/changes/76/962876/2","commands":{"Checkout":"git fetch https://review.opendev.org/openstack/ceilometer refs/changes/76/962876/2 \u0026\u0026 git checkout FETCH_HEAD","Cherry Pick":"git fetch https://review.opendev.org/openstack/ceilometer refs/changes/76/962876/2 \u0026\u0026 git cherry-pick FETCH_HEAD","Format Patch":"git fetch https://review.opendev.org/openstack/ceilometer refs/changes/76/962876/2 \u0026\u0026 git format-patch -1 --stdout FETCH_HEAD","Pull":"git pull https://review.opendev.org/openstack/ceilometer refs/changes/76/962876/2"}}},"commit":{"parents":[{"commit":"42a3dbb9e94f3f199556794d7660e24935156494","subject":"Merge \"Remove outdated options from local.conf sample\"","web_links":[{"name":"gitea","tooltip":"Open in GitWeb","url":"https://opendev.org/openstack/ceilometer/commit/42a3dbb9e94f3f199556794d7660e24935156494"}]}],"author":{"name":"Emma Foley","email":"efoley@redhat.com","date":"2025-10-02 16:42:54.000000000","tz":-240},"committer":{"name":"Emma Foley","email":"efoley@redhat.com","date":"2025-10-06 11:46:40.000000000","tz":-240},"subject":"Remove libvirt dependency from test_discovery","message":"Remove libvirt dependency from test_discovery\n\nThe test_discovery module only used libvirt for a single exception\nclass (libvirtError) and one constant (VIR_ERR_NO_DOMAIN_METADATA)\nin one test method. This made libvirt-python a heavy and\nunnecessary test dependency.\n\nReplace libvirt.libvirtError with FakeLibvirtError, a lightweight\nmock exception class that implements the same get_error_code()\ninterface. Define VIR_ERR_NO_DOMAIN_METADATA locally with value\n80 as documented in libvirt API documentation. Simplify the\nFakeManualInstanceDomain.metadata() method to directly raise the\nexception with the error code passed to the constructor.\n\nRemove libvirt-python from test-requirements.txt as it is no\nlonger needed by this test module.\n\nGenerated-By: claude-code\nChange-Id: I922e3861c30ba974714179c9144b770fb303260b\nSigned-off-by: Emma Foley \u003cefoley@redhat.com\u003e\n","web_links":[{"name":"gitea","tooltip":"Open in GitWeb","url":"https://opendev.org/openstack/ceilometer/commit/426ab555d27bd7316c3c6b2e798393e77c632c01"}],"resolve_conflicts_web_links":[{"name":"gitea","tooltip":"Open in GitWeb","url":"https://opendev.org/openstack/ceilometer/commit/426ab555d27bd7316c3c6b2e798393e77c632c01"}]},"branch":"refs/heads/master"}},"requirements":[],"submit_records":[{"rule_name":"gerrit~DefaultSubmitRule","status":"CLOSED","labels":[{"label":"Verified","status":"MAY","applied_by":{"_account_id":22348,"name":"Zuul","username":"zuul","tags":["SERVICE_USER"]}},{"label":"Code-Review","status":"MAY","applied_by":{"_account_id":4264,"name":"Matthias Runge","email":"mrunge@redhat.com","username":"mrunge"}},{"label":"Workflow","status":"MAY","applied_by":{"_account_id":34975,"name":"Jaromír Wysoglad","email":"jwysogla@redhat.com","username":"jwysogla"}}]}],"submit_requirements":[{"name":"Verified","description":"Verified in gate by CI","status":"SATISFIED","is_legacy":false,"submittability_expression_result":{"expression":"label:Verified\u003dMAX AND -label:Verified\u003dMIN","fulfilled":true,"status":"PASS","passing_atoms":["label:Verified\u003dMAX"],"failing_atoms":["label:Verified\u003dMIN"],"atom_explanations":{}}},{"name":"Code-Review","description":"Code reviewed by core reviewer","status":"SATISFIED","is_legacy":false,"submittability_expression_result":{"expression":"label:Code-Review\u003dMAX AND -label:Code-Review\u003dMIN","fulfilled":true,"status":"PASS","passing_atoms":["label:Code-Review\u003dMAX"],"failing_atoms":["label:Code-Review\u003dMIN"],"atom_explanations":{}}},{"name":"Workflow","description":"Approved for gate by core reviewer","status":"SATISFIED","is_legacy":false,"submittability_expression_result":{"expression":"label:Workflow\u003dMAX AND -label:Workflow\u003dMIN","fulfilled":true,"status":"PASS","passing_atoms":["label:Workflow\u003dMAX"],"failing_atoms":["label:Workflow\u003dMIN"],"atom_explanations":{}}}]}
