Skip to content

Commit 86eca5d

Browse files
committed
[API] Adds machine_learning.reset_job
1 parent 3ed409b commit 86eca5d

File tree

2 files changed

+102
-0
lines changed

2 files changed

+102
-0
lines changed
Lines changed: 56 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,56 @@
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 API
20+
module MachineLearning
21+
module Actions
22+
# Resets an existing anomaly detection job.
23+
#
24+
# @option arguments [String] :job_id The ID of the job to reset
25+
# @option arguments [Boolean] :wait_for_completion Should this request wait until the operation has completed before returning
26+
# @option arguments [Hash] :headers Custom HTTP headers
27+
#
28+
# @see https://www.elastic.co/guide/en/elasticsearch/reference/current/ml-reset-job.html
29+
#
30+
def reset_job(arguments = {})
31+
raise ArgumentError, "Required argument 'job_id' missing" unless arguments[:job_id]
32+
33+
headers = arguments.delete(:headers) || {}
34+
35+
arguments = arguments.clone
36+
37+
_job_id = arguments.delete(:job_id)
38+
39+
method = Elasticsearch::API::HTTP_POST
40+
path = "_ml/anomaly_detectors/#{Utils.__listify(_job_id)}/_reset"
41+
params = Utils.__validate_and_extract_params arguments, ParamsRegistry.get(__method__)
42+
43+
body = nil
44+
perform_request(method, path, params, body, headers).body
45+
end
46+
47+
# Register this action with its valid params when the module is loaded.
48+
#
49+
# @since 6.2.0
50+
ParamsRegistry.register(:reset_job, [
51+
:wait_for_completion
52+
].freeze)
53+
end
54+
end
55+
end
56+
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::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)