|
37 | 37 | import org.apache.avro.util.Utf8;
|
38 | 38 | import org.apache.hadoop.conf.Configuration;
|
39 | 39 | import org.apache.hadoop.fs.Path;
|
| 40 | +import org.apache.parquet.UntrustedStringableClass; |
40 | 41 | import org.apache.parquet.hadoop.ParquetReader;
|
41 | 42 | import org.apache.parquet.hadoop.ParquetWriter;
|
42 | 43 | import org.apache.parquet.hadoop.metadata.CompressionCodecName;
|
@@ -76,6 +77,40 @@ public void testWriteReflectReadGeneric() throws IOException {
|
76 | 77 | }
|
77 | 78 | }
|
78 | 79 |
|
| 80 | + @Test(expected = SecurityException.class) |
| 81 | + public void testUntrustedStringableClass() throws IOException { |
| 82 | + new AvroConverters.FieldStringableConverter( |
| 83 | + new ParentValueContainer() { |
| 84 | + @Override |
| 85 | + public void add(Object value) {} |
| 86 | + |
| 87 | + @Override |
| 88 | + public void addBoolean(boolean value) {} |
| 89 | + |
| 90 | + @Override |
| 91 | + public void addInt(int value) {} |
| 92 | + |
| 93 | + @Override |
| 94 | + public void addLong(long value) {} |
| 95 | + |
| 96 | + @Override |
| 97 | + public void addFloat(float value) {} |
| 98 | + |
| 99 | + @Override |
| 100 | + public void addDouble(double value) {} |
| 101 | + |
| 102 | + @Override |
| 103 | + public void addChar(char value) {} |
| 104 | + |
| 105 | + @Override |
| 106 | + public void addByte(byte value) {} |
| 107 | + |
| 108 | + @Override |
| 109 | + public void addShort(short value) {} |
| 110 | + }, |
| 111 | + UntrustedStringableClass.class); |
| 112 | + } |
| 113 | + |
79 | 114 | private GenericRecord getGenericPojoUtf8() {
|
80 | 115 | Schema schema = ReflectData.get().getSchema(Pojo.class);
|
81 | 116 | GenericData.Record record = new GenericData.Record(schema);
|
|
0 commit comments