t/30_Logger_Async/40_trace_request.t (78 lines of code) (raw):
# Licensed to Elasticsearch B.V. under one or more contributor
# license agreements. See the NOTICE file distributed with
# this work for additional information regarding copyright
# ownership. Elasticsearch B.V. licenses this file to you 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.
use Test::More;
use Test::Exception;
use Search::Elasticsearch::Async;
do './t/lib/LogCallback.pl' or die( $@ || $! );
ok my $e
= Search::Elasticsearch::Async->new(
nodes => 'https://foo.bar:444/some/path' ), 'Client';
isa_ok my $l = $e->logger, 'Search::Elasticsearch::Logger::LogAny', 'Logger';
my $c = $e->transport->cxn_pool->cxns->[0];
ok $c->does('Search::Elasticsearch::Role::Cxn'),
'Does Search::Elasticsearch::Role::Cxn';
# No body
ok $l->trace_request(
$c,
{ method => 'POST',
qs => { foo => 'bar' },
serialize => 'std',
path => '/xyz'
}
),
'No body';
is $format, <<'REQUEST', 'No body - format';
# Request to: https://foo.bar:444/some/path
curl -XPOST 'http://localhost:9200/xyz?foo=bar&pretty=true'
REQUEST
# Std body
ok $l->trace_request(
$c,
{ method => 'POST',
qs => { foo => 'bar' },
serialize => 'std',
path => '/xyz',
body => { foo => qq(bar\n'baz) },
data => qq({"foo":"bar\n'baz"}),
mime_type => 'application/json',
}
),
'Body';
is $format, <<'REQUEST', 'Body - format';
# Request to: https://foo.bar:444/some/path
curl -H "Content-type: application/json" -XPOST 'http://localhost:9200/xyz?foo=bar&pretty=true' -d '
{
"foo" : "bar\n\u0027baz"
}
'
REQUEST
# Bulk body
ok $l->trace_request(
$c,
{ method => 'POST',
qs => { foo => 'bar' },
serialize => 'bulk',
path => '/xyz',
body => [ { foo => qq(bar\n'baz) }, { foo => qq(bar\n'baz) } ],
data => qq({"foo":"bar\\n\\u0027baz"}\n{"foo":"bar\\n\\u0027baz"}\n),
mime_type => 'application/json',
}
),
'Bulk';
is $format, <<'REQUEST', 'Bulk - format';
# Request to: https://foo.bar:444/some/path
curl -H "Content-type: application/json" -XPOST 'http://localhost:9200/xyz?foo=bar&pretty=true' -d '
{"foo":"bar\n\u0027baz"}
{"foo":"bar\n\u0027baz"}
'
REQUEST
# String body
ok $l->trace_request(
$c,
{ method => 'POST',
qs => { foo => 'bar' },
serialize => 'std',
path => '/xyz',
body => qq(The quick brown fox\njumped over the lazy dog's basket),
mime_type => 'application/json',
}
),
'Body string';
is $format, <<'REQUEST', 'Body string - format';
# Request to: https://foo.bar:444/some/path
curl -H "Content-type: application/json" -XPOST 'http://localhost:9200/xyz?foo=bar&pretty=true' -d '
The quick brown fox
jumped over the lazy dog\u0027s basket'
REQUEST
done_testing;