Skip to content

Commit 007668e

Browse files
committed
[API] Adds machine_learning.reset_job
1 parent 5f5a25a commit 007668e

File tree

2 files changed

+105
-0
lines changed

2 files changed

+105
-0
lines changed
Lines changed: 59 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,59 @@
1+
# Licensed to Elasticsearch B.V. under one or more contributor
2+
# license agreements. See the NOTICE file distributed with
3+
# this work for additional information regarding copyright
4+
# ownership. Elasticsearch B.V. licenses this file to you under
5+
# the Apache License, Version 2.0 (the "License"); you may
6+
# not use this file except in compliance with the License.
7+
# You may obtain a copy of the License at
8+
#
9+
# http://www.apache.org/licenses/LICENSE-2.0
10+
#
11+
# Unless required by applicable law or agreed to in writing,
12+
# software distributed under the License is distributed on an
13+
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
14+
# KIND, either express or implied. See the License for the
15+
# specific language governing permissions and limitations
16+
# under the License.
17+
18+
module Elasticsearch
19+
module XPack
20+
module API
21+
module MachineLearning
22+
module Actions
23+
# Resets an existing anomaly detection job.
24+
#
25+
# @option arguments [String] :job_id The ID of the job to reset
26+
# @option arguments [Boolean] :wait_for_completion Should this request wait until the operation has completed before returning
27+
# @option arguments [Hash] :headers Custom HTTP headers
28+
#
29+
# @see https://www.elastic.co/guide/en/elasticsearch/reference/7.x/ml-reset-job.html
30+
#
31+
def reset_job(arguments = {})
32+
raise ArgumentError, "Required argument 'job_id' missing" unless arguments[:job_id]
33+
34+
headers = arguments.delete(:headers) || {}
35+
36+
arguments = arguments.clone
37+
38+
_job_id = arguments.delete(:job_id)
39+
40+
method = Elasticsearch::API::HTTP_POST
41+
path = "_ml/anomaly_detectors/#{Elasticsearch::API::Utils.__listify(_job_id)}/_reset"
42+
params = Elasticsearch::API::Utils.__validate_and_extract_params arguments,
43+
ParamsRegistry.get(__method__)
44+
45+
body = nil
46+
perform_request(method, path, params, body, headers).body
47+
end
48+
49+
# Register this action with its valid params when the module is loaded.
50+
#
51+
# @since 6.2.0
52+
ParamsRegistry.register(:reset_job, [
53+
:wait_for_completion
54+
].freeze)
55+
end
56+
end
57+
end
58+
end
59+
end
Lines changed: 46 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,46 @@
1+
# Licensed to Elasticsearch B.V. under one or more contributor
2+
# license agreements. See the NOTICE file distributed with
3+
# this work for additional information regarding copyright
4+
# ownership. Elasticsearch B.V. licenses this file to you under
5+
# the Apache License, Version 2.0 (the "License"); you may
6+
# not use this file except in compliance with the License.
7+
# You may obtain a copy of the License at
8+
#
9+
# http://www.apache.org/licenses/LICENSE-2.0
10+
#
11+
# Unless required by applicable law or agreed to in writing,
12+
# software distributed under the License is distributed on an
13+
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
14+
# KIND, either express or implied. See the License for the
15+
# specific language governing permissions and limitations
16+
# under the License.
17+
18+
require 'spec_helper'
19+
20+
describe 'client#ml.reset_job' do
21+
let(:expected_args) do
22+
[
23+
'POST',
24+
'_ml/anomaly_detectors/foo/_reset',
25+
{},
26+
nil,
27+
{}
28+
]
29+
end
30+
31+
it 'performs the request' do
32+
expect(client_double.ml.reset_job(job_id: 'foo')).to eq({})
33+
end
34+
35+
let(:client) do
36+
Class.new { include Elasticsearch::XPack::API }.new
37+
end
38+
39+
context 'when a job_id is not provided' do
40+
it 'raises an exception' do
41+
expect {
42+
client.ml.reset_job
43+
}.to raise_exception(ArgumentError)
44+
end
45+
end
46+
end

0 commit comments

Comments
 (0)