當前位置: 首頁>>代碼示例>>Java>>正文


Java JsonUtil類代碼示例

本文整理匯總了Java中org.apache.kylin.common.util.JsonUtil的典型用法代碼示例。如果您正苦於以下問題:Java JsonUtil類的具體用法?Java JsonUtil怎麽用?Java JsonUtil使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


JsonUtil類屬於org.apache.kylin.common.util包,在下文中一共展示了JsonUtil類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: getKylinProperties

import org.apache.kylin.common.util.JsonUtil; //導入依賴的package包/類
public String getKylinProperties() throws IOException {
    String url = baseUrl + "/admin/config";
    HttpGet request = new HttpGet(url);
    HttpResponse response = null;
    try {
        response = client.execute(request);
        String msg = EntityUtils.toString(response.getEntity());
        Map<String, String> map = JsonUtil.readValueAsMap(msg);
        msg = map.get("config");

        if (response.getStatusLine().getStatusCode() != 200)
            throw new IOException("Invalid response " + response.getStatusLine().getStatusCode()
                    + " with cache wipe url " + url + "\n" + msg);
        return msg;
    } finally {
        cleanup(request, response);
    }
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:19,代碼來源:RestClient.java

示例2: testBasics

import org.apache.kylin.common.util.JsonUtil; //導入依賴的package包/類
@Test
public void testBasics() throws Exception {
    BadQueryHistory history = BadQueryHistoryManager.getInstance(getTestConfig())
            .getBadQueriesForProject("default");
    System.out.println(JsonUtil.writeValueAsIndentString(history));

    NavigableSet<BadQueryEntry> entries = history.getEntries();
    assertEquals(3, entries.size());

    BadQueryEntry entry1 = entries.first();
    assertEquals("Pushdown", entry1.getAdj());
    assertEquals("sandbox.hortonworks.com", entry1.getServer());
    assertEquals("select * from test_kylin_fact limit 10", entry1.getSql());

    entries.pollFirst();
    BadQueryEntry entry2 = entries.first();
    assertTrue(entry2.getStartTime() > entry1.getStartTime());
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:19,代碼來源:BadQueryHistoryManagerTest.java

示例3: buildDictionary

import org.apache.kylin.common.util.JsonUtil; //導入依賴的package包/類
public DictionaryInfo buildDictionary(TblColRef col, IReadableTable inpTable, String builderClass) throws IOException {
    if (inpTable.exists() == false)
        return null;

    logger.info("building dictionary for " + col);

    DictionaryInfo dictInfo = createDictionaryInfo(col, inpTable);
    String dupInfo = checkDupByInfo(dictInfo);
    if (dupInfo != null) {
        logger.info("Identical dictionary input " + dictInfo.getInput() + ", reuse existing dictionary at " + dupInfo);
        return getDictionaryInfo(dupInfo);
    }

    logger.info("Building dictionary object " + JsonUtil.writeValueAsString(dictInfo));

    Dictionary<String> dictionary;
    dictionary = buildDictFromReadableTable(inpTable, dictInfo, builderClass, col);
    return trySaveNewDict(dictionary, dictInfo);
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:20,代碼來源:DictionaryManager.java

示例4: setCuboids

import org.apache.kylin.common.util.JsonUtil; //導入依賴的package包/類
public void setCuboids(Map<Long, Long> cuboids) {
    if (cuboids == null)
        return;
    if (cuboids.isEmpty()) {
        cuboidBytes = null;
        return;
    }

    try {
        String str = JsonUtil.writeValueAsString(cuboids);
        byte[] compressed = CompressionUtils.compress(str.getBytes("UTF-8"));
        cuboidBytes = compressed;
    } catch (IOException e) {
        throw new RuntimeException(e);
    }
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:17,代碼來源:CubeInstance.java

示例5: dump

import org.apache.kylin.common.util.JsonUtil; //導入依賴的package包/類
public static void dump(File f) throws IOException {
    if (f.isDirectory()) {
        File[] files = f.listFiles();
        if (files == null) {
            return;
        }
        for (File c : files)
            dump(c);
        return;
    }

    if (f.getName().endsWith(".dict")) {
        DictionaryInfoSerializer ser = new DictionaryInfoSerializer();
        DictionaryInfo dictInfo = ser.deserialize(new DataInputStream(new FileInputStream(f)));

        System.out.println("============================================================================");
        System.out.println("File: " + f.getAbsolutePath());
        System.out.println(new Date(dictInfo.getLastModified()));
        System.out.println(JsonUtil.writeValueAsIndentString(dictInfo));
        dictInfo.getDictionaryObject().dump(System.out);
        System.out.println();
    }
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:24,代碼來源:DumpDictionaryCLI.java

示例6: testGoodDesc

import org.apache.kylin.common.util.JsonUtil; //導入依賴的package包/類
@Test
public void testGoodDesc() throws IOException {
    AggregationGroupRule rule = getAggregationGroupRule();

    for (File f : new File(LocalFileMetadataTestCase.LOCALMETA_TEMP_DATA + "/cube_desc/").listFiles()) {
        if (!f.getName().endsWith("json")) {
            continue;
        }
        CubeDesc desc = JsonUtil.readValue(new FileInputStream(f), CubeDesc.class);
        desc.init(getTestConfig());
        ValidateContext vContext = new ValidateContext();
        rule.validate(desc, vContext);
        //vContext.print(System.out);
        assertTrue(vContext.getResults().length == 0);
    }
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:17,代碼來源:AggregationGroupRuleTest.java

示例7: testGoodBecomeBadDesc

import org.apache.kylin.common.util.JsonUtil; //導入依賴的package包/類
@Test
public void testGoodBecomeBadDesc() throws IOException {
    AggregationGroupRule rule = new AggregationGroupRule() {
        @Override
        protected long getMaxCombinations(CubeDesc cubeDesc) {
            return 2;
        }
    };

    for (File f : new File(LocalFileMetadataTestCase.LOCALMETA_TEMP_DATA + "/cube_desc/").listFiles()) {
        System.out.println(f.getName());
        CubeDesc desc = JsonUtil.readValue(new FileInputStream(f), CubeDesc.class);
        try {
            desc.init(getTestConfig());
        } catch (Exception e) {
            // Ignore any exception here, validation may fail for bad json
        }
        ValidateContext vContext = new ValidateContext();
        rule.validate(desc, vContext);
        //vContext.print(System.out);
        assertTrue(vContext.getResults().length > 0);
        assertTrue(vContext.getResults()[0].getMessage().startsWith("Aggregation group 1 has too many combinations"));
    }
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:25,代碼來源:AggregationGroupRuleTest.java

示例8: testCombinationIntOverflow

import org.apache.kylin.common.util.JsonUtil; //導入依賴的package包/類
@Test
public void testCombinationIntOverflow() throws IOException {
    for (File f : new File(LocalFileMetadataTestCase.LOCALMETA_TEMP_DATA + "/cube_desc/").listFiles()) {
        if (f.getName().endsWith("bad")) {
            String path = f.getPath();
            f.renameTo(new File(path.substring(0, path.length() - 4)));
        }
    }

    ValidateContext vContext = new ValidateContext();
    CubeDesc desc = JsonUtil.readValue(new FileInputStream(LocalFileMetadataTestCase.LOCALMETA_TEMP_DATA + "/cube_desc/ut_cube_desc_combination_int_overflow.json"), CubeDesc.class);

    IValidatorRule<CubeDesc> rule = getAggregationGroupRule();
    try {
        desc.init(getTestConfig());
    } catch (Exception ex) {
        // as it's a failure case, it should throw exception
    }
    rule.validate(desc, vContext);
    assertEquals(1, vContext.getResults().length);
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:22,代碼來源:AggregationGroupRuleTest.java

示例9: testDictionaryDesc

import org.apache.kylin.common.util.JsonUtil; //導入依賴的package包/類
private void testDictionaryDesc(String expectMessage, DictionaryDesc... descs) throws IOException {
    DictionaryRule rule = new DictionaryRule();
    File f = new File(LocalFileMetadataTestCase.LOCALMETA_TEST_DATA + "/cube_desc/test_kylin_cube_without_slr_left_join_desc.json");
    CubeDesc desc = JsonUtil.readValue(new FileInputStream(f), CubeDesc.class);

    List<DictionaryDesc> newDicts = Lists.newArrayList(desc.getDictionaries());
    for (DictionaryDesc dictDesc : descs) {
        newDicts.add(dictDesc);
    }
    desc.setDictionaries(newDicts);

    desc.init(config);
    ValidateContext vContext = new ValidateContext();
    rule.validate(desc, vContext);

    if (expectMessage == null) {
        assertTrue(vContext.getResults().length == 0);
    } else {
        assertTrue(vContext.getResults().length == 1);
        String actualMessage = vContext.getResults()[0].getMessage();
        assertTrue(actualMessage.startsWith(expectMessage));
    }
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:24,代碼來源:DictionaryRuleTest.java

示例10: updateModelDesc

import org.apache.kylin.common.util.JsonUtil; //導入依賴的package包/類
@RequestMapping(value = "", method = { RequestMethod.PUT }, produces = { "application/json" })
@ResponseBody
public ModelRequest updateModelDesc(@RequestBody ModelRequest modelRequest) throws JsonProcessingException {
    DataModelDesc modelDesc = deserializeDataModelDesc(modelRequest);
    if (modelDesc == null) {
        return modelRequest;
    }
    try {
        modelDesc = modelService.updateModelAndDesc(modelRequest.getProject(), modelDesc);
    } catch (AccessDeniedException accessDeniedException) {
        throw new ForbiddenException("You don't have right to update this model.");
    } catch (Exception e) {
        logger.error("Failed to deal with the request:" + e.getLocalizedMessage(), e);
        throw new InternalErrorException("Failed to deal with the request: " + e.getLocalizedMessage());
    }

    if (modelDesc.getError().isEmpty()) {
        modelRequest.setSuccessful(true);
    } else {
        logger.warn("Model " + modelDesc.getName() + " fail to update because " + modelDesc.getError());
        updateRequest(modelRequest, false, omitMessage(modelDesc.getError()));
    }
    String descData = JsonUtil.writeValueAsIndentString(modelDesc);
    modelRequest.setModelDescData(descData);
    return modelRequest;
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:27,代碼來源:ModelController.java

示例11: testReadTableDesc

import org.apache.kylin.common.util.JsonUtil; //導入依賴的package包/類
@Test
public void testReadTableDesc() throws IOException {
    String requestTableData = "{\"name\":\"my_table_name\",\"source_type\":1,\"columns\":[{\"id\":1,\"name\":" +
            "\"amount\",\"datatype\":\"decimal\"},{\"id\":2,\"name\":\"category\",\"datatype\":\"varchar(256)\"}," +
            "{\"id\":3,\"name\":\"order_time\",\"datatype\":\"timestamp\"},{\"id\":4,\"name\":\"device\"," +
            "\"datatype\":\"varchar(256)\"},{\"id\":5,\"name\":\"qty\",\"datatype\":\"int\"},{\"id\":6,\"name\":" +
            "\"user_id\",\"datatype\":\"varchar(256)\"},{\"id\":7,\"name\":\"user_age\",\"datatype\":\"int\"}," +
            "{\"id\":8,\"name\":\"user_gender\",\"datatype\":\"varchar(256)\"},{\"id\":9,\"name\":\"currency\"," +
            "\"datatype\":\"varchar(256)\"},{\"id\":10,\"name\":\"country\",\"datatype\":\"varchar(256)\"}," +
            "{\"id\":11,\"name\":\"year_start\",\"datatype\":\"date\"},{\"id\":12,\"name\":\"quarter_start\"," +
            "\"datatype\":\"date\"},{\"id\":13,\"name\":\"month_start\",\"datatype\":\"date\"},{\"id\":14," +
            "\"name\":\"week_start\",\"datatype\":\"date\"},{\"id\":15,\"name\":\"day_start\",\"datatype\":" +
            "\"date\"},{\"id\":16,\"name\":\"hour_start\",\"datatype\":\"timestamp\"},{\"id\":17,\"name\":" +
            "\"minute_start\",\"datatype\":\"timestamp\"}],\"database\":\"my_database_name\"}";
    TableDesc desc = JsonUtil.readValue(requestTableData, TableDesc.class);
    String[] dbTable = HadoopUtil.parseHiveTableName(desc.getIdentity());
    desc.setName(dbTable[1]);
    desc.setDatabase(dbTable[0]);
    Assert.assertEquals("my_table_name".toUpperCase(), desc.getName());
    Assert.assertEquals("my_database_name".toUpperCase(), desc.getDatabase());
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:22,代碼來源:StreamingControllerTest.java

示例12: getValue

import org.apache.kylin.common.util.JsonUtil; //導入依賴的package包/類
@Override
/**
 * Event type does not belong to value part, it's for classification
 */
public byte[] getValue() {
    try {
        ByteArrayOutputStream baos = _localBaos.get();
        if (baos == null) {
            baos = new ByteArrayOutputStream();
            _localBaos.set(baos);
        }
        baos.reset();
        JsonUtil.writeValue(baos, getValueRaw());
        return baos.toByteArray();
    } catch (IOException e) {
        throw new RuntimeException(e);//in mem, should not happen
    }
}
 
開發者ID:apache,項目名稱:kylin,代碼行數:19,代碼來源:RecordEvent.java

示例13: saveTableExd

import org.apache.kylin.common.util.JsonUtil; //導入依賴的package包/類
public void saveTableExd(String tableId, Map<String, String> tableExdProperties) throws IOException {
    if (tableId == null) {
        throw new IllegalArgumentException("tableId couldn't be null");
    }
    TableDesc srcTable = srcTableMap.get(tableId);
    if (srcTable == null) {
        throw new IllegalArgumentException("Couldn't find Source Table with identifier: " + tableId);
    }

    String path = TableDesc.concatExdResourcePath(tableId);

    ByteArrayOutputStream os = new ByteArrayOutputStream();
    JsonUtil.writeValueIndent(os, tableExdProperties);
    os.flush();
    InputStream is = new ByteArrayInputStream(os.toByteArray());
    getStore().putResource(path, is, System.currentTimeMillis());
    os.close();
    is.close();

    srcTableExdMap.putLocal(tableId, tableExdProperties);
}
 
開發者ID:KylinOLAP,項目名稱:Kylin,代碼行數:22,代碼來源:MetadataManager.java

示例14: dump

import org.apache.kylin.common.util.JsonUtil; //導入依賴的package包/類
public static void dump(File f) throws IOException {
    if (f.isDirectory()) {
        for (File c : f.listFiles())
            dump(c);
        return;
    }

    if (f.getName().endsWith(".dict")) {
        DictionaryInfoSerializer ser = new DictionaryInfoSerializer();
        DictionaryInfo dictInfo = ser.deserialize(new DataInputStream(new FileInputStream(f)));

        System.out.println("============================================================================");
        System.out.println("File: " + f.getAbsolutePath());
        System.out.println(new Date(dictInfo.getLastModified()));
        System.out.println(JsonUtil.writeValueAsIndentString(dictInfo));
        dictInfo.getDictionaryObject().dump(System.out);
        System.out.println();
    }
}
 
開發者ID:KylinOLAP,項目名稱:Kylin,代碼行數:20,代碼來源:DumpDictionaryCLI.java

示例15: basic

import org.apache.kylin.common.util.JsonUtil; //導入依賴的package包/類
@Test
@Ignore("hive not ready")
public void basic() throws Exception {
    CubeDesc cubeDesc = CubeDescManager.getInstance(getTestConfig()).getCubeDesc("test_kylin_cube_without_slr_desc");
    TblColRef col = cubeDesc.findColumnRef("DEFAULT.TEST_CATEGORY_GROUPINGS", "META_CATEG_NAME");

    DictionaryInfo info1 = dictMgr.buildDictionary(cubeDesc.getModel(), cubeDesc.getRowkey().getDictionary(col), col, null);
    System.out.println(JsonUtil.writeValueAsIndentString(info1));

    DictionaryInfo info2 = dictMgr.buildDictionary(cubeDesc.getModel(), cubeDesc.getRowkey().getDictionary(col), col, null);
    System.out.println(JsonUtil.writeValueAsIndentString(info2));

    assertTrue(info1.getUuid() == info2.getUuid());

    assertTrue(info1 == dictMgr.getDictionaryInfo(info1.getResourcePath()));
    assertTrue(info2 == dictMgr.getDictionaryInfo(info2.getResourcePath()));

    assertTrue(info1.getDictionaryObject() == info2.getDictionaryObject());

    touchDictValues(info1);
}
 
開發者ID:KylinOLAP,項目名稱:Kylin,代碼行數:22,代碼來源:DictionaryManagerTest.java


注:本文中的org.apache.kylin.common.util.JsonUtil類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。