mirror of
https://github.com/centreon/centreon-plugins.git
synced 2025-07-31 01:24:35 +02:00
New pack LatenceTech : mode throughput
Co-authored-by: thibaults-centreon <tscheitenberger@centreon.com>
This commit is contained in:
parent
b1bee0cca1
commit
e861e4d32a
155
src/apps/monitoring/latencetech/restapi/mode/throughput.pm
Normal file
155
src/apps/monitoring/latencetech/restapi/mode/throughput.pm
Normal file
@ -0,0 +1,155 @@
|
|||||||
|
#
|
||||||
|
# Copyright 2025 Centreon (http://www.centreon.com/)
|
||||||
|
#
|
||||||
|
# Centreon is a full-fledged industry-strength solution that meets
|
||||||
|
# the needs in IT infrastructure and application monitoring for
|
||||||
|
# service performance.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
#
|
||||||
|
|
||||||
|
package apps::monitoring::latencetech::restapi::mode::throughput;
|
||||||
|
|
||||||
|
use base qw(centreon::plugins::templates::counter);
|
||||||
|
|
||||||
|
use strict;
|
||||||
|
use warnings;
|
||||||
|
|
||||||
|
sub set_counters {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
$self->{maps_counters_type} = [
|
||||||
|
{ name => 'global', type => 0, cb_prefix_output => 'prefix_output' }
|
||||||
|
];
|
||||||
|
|
||||||
|
$self->{maps_counters}->{global} = [
|
||||||
|
{ label => 'lifbe-download', nlabel => 'lifbe.download.bandwidth.mbps', set => {
|
||||||
|
key_values => [ { name => 'lifbeDownload' }, { name => 'display' } ],
|
||||||
|
output_template => 'LifBE Download: %.2fmbps',
|
||||||
|
perfdatas => [
|
||||||
|
{ value => 'lifbeDownload', template => '%.2f',
|
||||||
|
min => 0, unit => 'mbps', label_extra_instance => 1, instance_use => 'display' },
|
||||||
|
],
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ label => 'lifbe-upload', nlabel => 'lifbe.upload.bandwidth.mbps', set => {
|
||||||
|
key_values => [ { name => 'lifbeUpload' }, { name => 'display' } ],
|
||||||
|
output_template => 'LifBE Upload: %.2fmbps',
|
||||||
|
perfdatas => [
|
||||||
|
{ value => 'lifbeUpload', template => '%.2f',
|
||||||
|
min => 0, unit => 'mbps', label_extra_instance => 1, instance_use => 'display' },
|
||||||
|
],
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ label => 'jitter-download', nlabel => 'jitter.download.time.milliseconds', set => {
|
||||||
|
key_values => [ { name => 'jitterDownload' }, { name => 'display' } ],
|
||||||
|
output_template => 'Jitter Download Time: %.2fms',
|
||||||
|
perfdatas => [
|
||||||
|
{ value => 'jitterDownload', template => '%.2f',
|
||||||
|
min => 0, unit => 'ms', label_extra_instance => 1, instance_use => 'display' },
|
||||||
|
],
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ label => 'jitter-upload', nlabel => 'jitter.upload.time.milliseconds', set => {
|
||||||
|
key_values => [ { name => 'jitterUpload' }, { name => 'display' } ],
|
||||||
|
output_template => 'Jitter Upload Time: %.2fms',
|
||||||
|
perfdatas => [
|
||||||
|
{ value => 'jitterUpload', template => '%.2f',
|
||||||
|
min => 0, unit => 'ms', label_extra_instance => 1, instance_use => 'display' },
|
||||||
|
],
|
||||||
|
}
|
||||||
|
}
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
sub prefix_output {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
return "Agent '" . $options{instance_value}->{display} . "' ";
|
||||||
|
}
|
||||||
|
|
||||||
|
sub new {
|
||||||
|
my ($class, %options) = @_;
|
||||||
|
my $self = $class->SUPER::new(package => __PACKAGE__, %options, force_new_perfdata => 1);
|
||||||
|
bless $self, $class;
|
||||||
|
|
||||||
|
$options{options}->add_options(arguments => {});
|
||||||
|
|
||||||
|
return $self;
|
||||||
|
}
|
||||||
|
|
||||||
|
sub check_options {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
$self->SUPER::check_options(%options);
|
||||||
|
}
|
||||||
|
|
||||||
|
sub manage_selection {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
$self->{global} = {};
|
||||||
|
my $results = $options{custom}->request_api(endpoint => '/lifbe');
|
||||||
|
$self->{global}->{display} = $results->{agentID};
|
||||||
|
foreach my $kpi (keys %{$results}) {
|
||||||
|
$self->{global}->{$kpi} = $results->{$kpi};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
1;
|
||||||
|
|
||||||
|
__END__
|
||||||
|
|
||||||
|
=head1 MODE
|
||||||
|
|
||||||
|
Check agent throughput statistics.
|
||||||
|
|
||||||
|
=over 8
|
||||||
|
|
||||||
|
=item B<--agent-id>
|
||||||
|
|
||||||
|
Set the ID of the agent (mandatory option).
|
||||||
|
|
||||||
|
=item B<--warning-lifbe-download>
|
||||||
|
|
||||||
|
Warning thresholds for LifBE download bandwidth (in Mbps).
|
||||||
|
|
||||||
|
=item B<--critical-lifbe-download>
|
||||||
|
|
||||||
|
Critical thresholds for LifBE download bandwidth (in Mbps).
|
||||||
|
|
||||||
|
=item B<--warning-lifbe-upload>
|
||||||
|
|
||||||
|
Warning thresholds for LifBE upload bandwidth (in Mbps).
|
||||||
|
|
||||||
|
=item B<--critical-lifbe-upload>
|
||||||
|
|
||||||
|
Critical thresholds for LifBE upload bandwidth (in Mbps).
|
||||||
|
|
||||||
|
=item B<--warning-jitter-download>
|
||||||
|
|
||||||
|
Warning thresholds for jitter download time (in milliseconds).
|
||||||
|
|
||||||
|
=item B<--critical-jitter-download>
|
||||||
|
|
||||||
|
Critical thresholds for jitter download time (in milliseconds).
|
||||||
|
|
||||||
|
=item B<--warning-jitter-upload>
|
||||||
|
|
||||||
|
Warning thresholds for jitter upload time (in milliseconds).
|
||||||
|
|
||||||
|
=item B<--critical-jitter-upload>
|
||||||
|
|
||||||
|
Critical thresholds for jitter upload time (in milliseconds).
|
||||||
|
|
||||||
|
=back
|
||||||
|
|
||||||
|
=cut
|
@ -35,7 +35,8 @@ sub new {
|
|||||||
'discovery' => 'apps::monitoring::latencetech::restapi::mode::discovery',
|
'discovery' => 'apps::monitoring::latencetech::restapi::mode::discovery',
|
||||||
'forecast' => 'apps::monitoring::latencetech::restapi::mode::forecast',
|
'forecast' => 'apps::monitoring::latencetech::restapi::mode::forecast',
|
||||||
'latency' => 'apps::monitoring::latencetech::restapi::mode::latency',
|
'latency' => 'apps::monitoring::latencetech::restapi::mode::latency',
|
||||||
'radio' => 'apps::monitoring::latencetech::restapi::mode::radio'
|
'radio' => 'apps::monitoring::latencetech::restapi::mode::radio',
|
||||||
|
'throughput' => 'apps::monitoring::latencetech::restapi::mode::throughput'
|
||||||
};
|
};
|
||||||
|
|
||||||
$self->{custom_modes}->{api} = 'apps::monitoring::latencetech::restapi::custom::api';
|
$self->{custom_modes}->{api} = 'apps::monitoring::latencetech::restapi::custom::api';
|
||||||
|
@ -357,6 +357,35 @@
|
|||||||
}
|
}
|
||||||
],
|
],
|
||||||
"responseMode": null
|
"responseMode": null
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"uuid": "232fe410-d4af-42c9-8efa-919b0c576625",
|
||||||
|
"type": "http",
|
||||||
|
"documentation": "",
|
||||||
|
"method": "get",
|
||||||
|
"endpoint": "api/v1/lifbe",
|
||||||
|
"responses": [
|
||||||
|
{
|
||||||
|
"uuid": "93141e59-7bca-44f8-b094-72f56ffec4f6",
|
||||||
|
"body": "{\n \"CustomerID\": \"0\",\n \"agentID\": \"2\",\n \"time\": \"2025-07-25T13:53:19.725Z\",\n \"lifbeDownload\": 531.58,\n \"lifbeUpload\": 47.05,\n \"jitterDownload\": 1.17,\n \"jitterUpload\": 3.38,\n \"packetLossDownload\": 0,\n \"packetLossUpload\": 0,\n \"networkInterface\": \"MOBILE\",\n \"networkType\": \"MOBILE_5G\"\n}",
|
||||||
|
"latency": 0,
|
||||||
|
"statusCode": 200,
|
||||||
|
"label": "",
|
||||||
|
"headers": [],
|
||||||
|
"bodyType": "INLINE",
|
||||||
|
"filePath": "",
|
||||||
|
"databucketID": "",
|
||||||
|
"sendFileAsBody": false,
|
||||||
|
"rules": [],
|
||||||
|
"rulesOperator": "OR",
|
||||||
|
"disableTemplating": false,
|
||||||
|
"fallbackTo404": false,
|
||||||
|
"default": true,
|
||||||
|
"crudKey": "id",
|
||||||
|
"callbacks": []
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"responseMode": null
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"rootChildren": [
|
"rootChildren": [
|
||||||
@ -379,6 +408,10 @@
|
|||||||
{
|
{
|
||||||
"type": "route",
|
"type": "route",
|
||||||
"uuid": "6ba46385-639a-41c6-8890-c487af160499"
|
"uuid": "6ba46385-639a-41c6-8890-c487af160499"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "route",
|
||||||
|
"uuid": "232fe410-d4af-42c9-8efa-919b0c576625"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"proxyMode": false,
|
"proxyMode": false,
|
||||||
|
53
tests/apps/monitoring/latencetech/restapi/throughput.robot
Normal file
53
tests/apps/monitoring/latencetech/restapi/throughput.robot
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
*** Settings ***
|
||||||
|
Documentation Check the LatenceTech throughput mode with api custom mode
|
||||||
|
|
||||||
|
Resource ${CURDIR}${/}..${/}..${/}..${/}..${/}resources/import.resource
|
||||||
|
|
||||||
|
Suite Setup Start Mockoon ${MOCKOON_JSON}
|
||||||
|
Suite Teardown Stop Mockoon
|
||||||
|
Test Timeout 120s
|
||||||
|
|
||||||
|
*** Variables ***
|
||||||
|
${MOCKOON_JSON} ${CURDIR}${/}mockoon.json
|
||||||
|
|
||||||
|
${cmd} ${CENTREON_PLUGINS}
|
||||||
|
... --plugin=apps::monitoring::latencetech::restapi::plugin
|
||||||
|
... --custommode=api
|
||||||
|
... --mode=throughput
|
||||||
|
... --hostname=${HOSTNAME}
|
||||||
|
... --api-key=key
|
||||||
|
... --port=${APIPORT}
|
||||||
|
... --proto=http
|
||||||
|
|
||||||
|
*** Test Cases ***
|
||||||
|
Throughput ${tc}
|
||||||
|
[Documentation] Check agent throughput statistics.
|
||||||
|
[Tags] apps monitoring latencetech restapi
|
||||||
|
|
||||||
|
${command} Catenate
|
||||||
|
... ${cmd}
|
||||||
|
... --customer-id=0
|
||||||
|
... --agent-id=2
|
||||||
|
... ${extraoptions}
|
||||||
|
Log ${cmd}
|
||||||
|
Ctn Run Command And Check Result As Strings ${command} ${expected_result}
|
||||||
|
|
||||||
|
Examples: tc extraoptions expected_result --
|
||||||
|
... 1 ${EMPTY}
|
||||||
|
... OK: Agent '2' LifBE Download: 531.58mbps, LifBE Upload: 47.05mbps, Jitter Download Time: 1.17ms, Jitter Upload Time: 3.38ms | '2#lifbe.download.bandwidth.mbps'=531.58mbps;;;0; '2#lifbe.upload.bandwidth.mbps'=47.05mbps;;;0; '2#jitter.download.time.milliseconds'=1.17ms;;;0; '2#jitter.upload.time.milliseconds'=3.38ms;;;0;
|
||||||
|
... 2 --warning-lifbe-download=500
|
||||||
|
... WARNING: Agent '2' LifBE Download: 531.58mbps | '2#lifbe.download.bandwidth.mbps'=531.58mbps;0:500;;0; '2#lifbe.upload.bandwidth.mbps'=47.05mbps;;;0; '2#jitter.download.time.milliseconds'=1.17ms;;;0; '2#jitter.upload.time.milliseconds'=3.38ms;;;0;
|
||||||
|
... 3 --critical-lifbe-download=450
|
||||||
|
... CRITICAL: Agent '2' LifBE Download: 531.58mbps | '2#lifbe.download.bandwidth.mbps'=531.58mbps;;0:450;0; '2#lifbe.upload.bandwidth.mbps'=47.05mbps;;;0; '2#jitter.download.time.milliseconds'=1.17ms;;;0; '2#jitter.upload.time.milliseconds'=3.38ms;;;0;
|
||||||
|
... 4 --warning-lifbe-upload=45
|
||||||
|
... WARNING: Agent '2' LifBE Upload: 47.05mbps | '2#lifbe.download.bandwidth.mbps'=531.58mbps;;;0; '2#lifbe.upload.bandwidth.mbps'=47.05mbps;0:45;;0; '2#jitter.download.time.milliseconds'=1.17ms;;;0; '2#jitter.upload.time.milliseconds'=3.38ms;;;0;
|
||||||
|
... 5 --critical-lifbe-upload=40
|
||||||
|
... CRITICAL: Agent '2' LifBE Upload: 47.05mbps | '2#lifbe.download.bandwidth.mbps'=531.58mbps;;;0; '2#lifbe.upload.bandwidth.mbps'=47.05mbps;;0:40;0; '2#jitter.download.time.milliseconds'=1.17ms;;;0; '2#jitter.upload.time.milliseconds'=3.38ms;;;0;
|
||||||
|
... 6 --warning-jitter-download=0.9
|
||||||
|
... WARNING: Agent '2' Jitter Download Time: 1.17ms | '2#lifbe.download.bandwidth.mbps'=531.58mbps;;;0; '2#lifbe.upload.bandwidth.mbps'=47.05mbps;;;0; '2#jitter.download.time.milliseconds'=1.17ms;0:0.9;;0; '2#jitter.upload.time.milliseconds'=3.38ms;;;0;
|
||||||
|
... 7 --critical-jitter-download=1.1
|
||||||
|
... CRITICAL: Agent '2' Jitter Download Time: 1.17ms | '2#lifbe.download.bandwidth.mbps'=531.58mbps;;;0; '2#lifbe.upload.bandwidth.mbps'=47.05mbps;;;0; '2#jitter.download.time.milliseconds'=1.17ms;;0:1.1;0; '2#jitter.upload.time.milliseconds'=3.38ms;;;0;
|
||||||
|
... 8 --warning-jitter-upload=3
|
||||||
|
... WARNING: Agent '2' Jitter Upload Time: 3.38ms | '2#lifbe.download.bandwidth.mbps'=531.58mbps;;;0; '2#lifbe.upload.bandwidth.mbps'=47.05mbps;;;0; '2#jitter.download.time.milliseconds'=1.17ms;;;0; '2#jitter.upload.time.milliseconds'=3.38ms;0:3;;0;
|
||||||
|
... 9 --critical-jitter-upload=3.25
|
||||||
|
... CRITICAL: Agent '2' Jitter Upload Time: 3.38ms | '2#lifbe.download.bandwidth.mbps'=531.58mbps;;;0; '2#lifbe.upload.bandwidth.mbps'=47.05mbps;;;0; '2#jitter.download.time.milliseconds'=1.17ms;;;0; '2#jitter.upload.time.milliseconds'=3.38ms;;0:3.25;0;
|
Loading…
x
Reference in New Issue
Block a user