2010-08-19 15:33:57 +03:00
|
|
|
/*
|
2014-01-06 22:48:02 +01:00
|
|
|
* Licensed to Elasticsearch under one or more contributor
|
|
|
|
* license agreements. See the NOTICE file distributed with
|
|
|
|
* this work for additional information regarding copyright
|
|
|
|
* ownership. Elasticsearch 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
|
2010-08-19 15:33:57 +03:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
2013-09-11 12:49:49 -05:00
|
|
|
package org.elasticsearch.common.compress;
|
2010-08-19 15:33:57 +03:00
|
|
|
|
2014-08-07 15:44:36 -04:00
|
|
|
import org.apache.lucene.util.TestUtil;
|
2015-05-19 18:38:23 +02:00
|
|
|
import org.elasticsearch.common.bytes.BytesReference;
|
|
|
|
import org.elasticsearch.common.io.stream.BytesStreamOutput;
|
|
|
|
import org.elasticsearch.common.io.stream.StreamOutput;
|
2015-05-25 13:14:01 -04:00
|
|
|
import org.elasticsearch.common.settings.Settings;
|
2013-10-13 22:37:40 +02:00
|
|
|
import org.elasticsearch.test.ElasticsearchTestCase;
|
2015-05-19 18:38:23 +02:00
|
|
|
import org.junit.Assert;
|
2013-07-19 14:38:59 +02:00
|
|
|
import org.junit.Test;
|
2010-08-19 15:33:57 +03:00
|
|
|
|
|
|
|
import java.io.IOException;
|
2014-08-07 15:44:36 -04:00
|
|
|
import java.util.Random;
|
2010-08-19 15:33:57 +03:00
|
|
|
|
2011-12-06 02:42:25 +02:00
|
|
|
import static org.hamcrest.Matchers.equalTo;
|
|
|
|
import static org.hamcrest.Matchers.not;
|
2010-08-19 15:33:57 +03:00
|
|
|
|
|
|
|
/**
|
2011-12-06 02:42:25 +02:00
|
|
|
*
|
2010-08-19 15:33:57 +03:00
|
|
|
*/
|
2015-05-21 12:36:44 +02:00
|
|
|
public class CompressedXContentTests extends ElasticsearchTestCase {
|
2010-08-19 15:33:57 +03:00
|
|
|
|
2012-07-04 17:14:12 +02:00
|
|
|
@Test
|
|
|
|
public void simpleTestsLZF() throws IOException {
|
|
|
|
simpleTests("lzf");
|
|
|
|
}
|
|
|
|
|
2015-05-21 12:36:44 +02:00
|
|
|
private void assertEquals(CompressedXContent s1, CompressedXContent s2) {
|
2015-05-19 18:38:23 +02:00
|
|
|
Assert.assertEquals(s1, s2);
|
|
|
|
assertArrayEquals(s1.uncompressed(), s2.uncompressed());
|
|
|
|
assertEquals(s1.hashCode(), s2.hashCode());
|
|
|
|
}
|
|
|
|
|
2012-07-04 17:14:12 +02:00
|
|
|
public void simpleTests(String compressor) throws IOException {
|
2015-05-25 13:14:01 -04:00
|
|
|
CompressorFactory.configure(Settings.settingsBuilder().put("compress.default.type", compressor).build());
|
2015-05-21 12:36:44 +02:00
|
|
|
String str = "---\nf:this is a simple string";
|
|
|
|
CompressedXContent cstr = new CompressedXContent(str);
|
2010-08-19 15:33:57 +03:00
|
|
|
assertThat(cstr.string(), equalTo(str));
|
2015-05-21 12:36:44 +02:00
|
|
|
assertThat(new CompressedXContent(str), equalTo(cstr));
|
2010-08-19 18:45:15 +03:00
|
|
|
|
2015-05-21 12:36:44 +02:00
|
|
|
String str2 = "---\nf:this is a simple string 2";
|
|
|
|
CompressedXContent cstr2 = new CompressedXContent(str2);
|
2010-08-19 18:45:15 +03:00
|
|
|
assertThat(cstr2.string(), not(equalTo(str)));
|
2015-05-21 12:36:44 +02:00
|
|
|
assertThat(new CompressedXContent(str2), not(equalTo(cstr)));
|
|
|
|
assertEquals(new CompressedXContent(str2), cstr2);
|
2010-08-19 15:33:57 +03:00
|
|
|
}
|
2015-05-19 18:38:23 +02:00
|
|
|
|
2014-08-07 15:44:36 -04:00
|
|
|
public void testRandom() throws IOException {
|
|
|
|
String compressor = "lzf";
|
2015-05-25 13:14:01 -04:00
|
|
|
CompressorFactory.configure(Settings.settingsBuilder().put("compress.default.type", compressor).build());
|
2014-08-07 15:44:36 -04:00
|
|
|
Random r = getRandom();
|
2014-08-18 10:37:45 -04:00
|
|
|
for (int i = 0; i < 1000; i++) {
|
2014-08-07 15:44:36 -04:00
|
|
|
String string = TestUtil.randomUnicodeString(r, 10000);
|
2015-05-21 12:36:44 +02:00
|
|
|
// hack to make it detected as YAML
|
|
|
|
string = "---\n" + string;
|
|
|
|
CompressedXContent compressedXContent = new CompressedXContent(string);
|
|
|
|
assertThat(compressedXContent.string(), equalTo(string));
|
2014-08-07 15:44:36 -04:00
|
|
|
}
|
|
|
|
}
|
2015-05-19 18:38:23 +02:00
|
|
|
|
|
|
|
public void testDifferentCompressedRepresentation() throws Exception {
|
2015-05-21 12:36:44 +02:00
|
|
|
byte[] b = "---\nf:abcdefghijabcdefghij".getBytes("UTF-8");
|
2015-05-19 18:38:23 +02:00
|
|
|
CompressorFactory.defaultCompressor();
|
|
|
|
|
|
|
|
Compressor compressor = CompressorFactory.defaultCompressor();
|
|
|
|
BytesStreamOutput bout = new BytesStreamOutput();
|
|
|
|
StreamOutput out = compressor.streamOutput(bout);
|
|
|
|
out.writeBytes(b);
|
|
|
|
out.flush();
|
|
|
|
out.writeBytes(b);
|
|
|
|
out.close();
|
|
|
|
final BytesReference b1 = bout.bytes();
|
|
|
|
|
|
|
|
bout = new BytesStreamOutput();
|
|
|
|
out = compressor.streamOutput(bout);
|
|
|
|
out.writeBytes(b);
|
|
|
|
out.writeBytes(b);
|
|
|
|
out.close();
|
|
|
|
final BytesReference b2 = bout.bytes();
|
|
|
|
|
|
|
|
// because of the intermediate flush, the two compressed representations
|
|
|
|
// are different. It can also happen for other reasons like if hash tables
|
|
|
|
// of different size are being used
|
|
|
|
assertFalse(b1.equals(b2));
|
|
|
|
// we used the compressed representation directly and did not recompress
|
2015-05-21 12:36:44 +02:00
|
|
|
assertArrayEquals(b1.toBytes(), new CompressedXContent(b1).compressed());
|
|
|
|
assertArrayEquals(b2.toBytes(), new CompressedXContent(b2).compressed());
|
2015-05-19 18:38:23 +02:00
|
|
|
// but compressedstring instances are still equal
|
2015-05-21 12:36:44 +02:00
|
|
|
assertEquals(new CompressedXContent(b1), new CompressedXContent(b2));
|
2015-05-19 18:38:23 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public void testHashCode() throws IOException {
|
2015-05-21 12:36:44 +02:00
|
|
|
assertFalse(new CompressedXContent("{\"a\":\"b\"}").hashCode() == new CompressedXContent("{\"a\":\"c\"}").hashCode());
|
2015-05-19 18:38:23 +02:00
|
|
|
}
|
|
|
|
|
2010-08-19 15:33:57 +03:00
|
|
|
}
|