[
https://issues.apache.org/jira/browse/CAMEL-7296?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
Willem Jiang resolved CAMEL-7296.
---------------------------------
Resolution: Fixed
Fix Version/s: 2.14.0
Applied the patch into master, camel-2.13.x and camel-2.12.x.
> camel-hbase component have some bugs on Consumer side
> -----------------------------------------------------
>
> Key: CAMEL-7296
> URL: https://issues.apache.org/jira/browse/CAMEL-7296
> Project: Camel
> Issue Type: Bug
> Components: camel-hbase
> Affects Versions: 2.12.3
> Reporter: liugang
> Assignee: Willem Jiang
> Fix For: 2.12.4, 2.13.1, 2.14.0
>
>
> After I tried a little bit, I think there are 2 problems on Consumer side:
> # Returned value is null
> if we specified family and qualifier options in URI, then all returned values
> will be null. I did some investigation, and I found the problem is caused by
> the equals method of HBaseCell class. In poll() method of HBaseConsumer, the
> resultRow will apply rowModel first before insert the resultCell, see below
> code:
> {code}
> ....
> HBaseData data = new HBaseData();
> HBaseRow resultRow = new HBaseRow();
> resultRow.apply(rowModel); //the existing HBaseCell in
> rowModel will be insert into resultRow
> byte[] row = result.getRow();
>
> resultRow.setId(endpoint.getCamelContext().getTypeConverter().convertTo(rowModel.getRowType(),
> row));
> List<KeyValue> keyValues = result.list();
> if (keyValues != null) {
> for (KeyValue keyValue : keyValues) {
> String qualifier = new
> String(keyValue.getQualifier());
> String family = new String(keyValue.getFamily());
> HBaseCell resultCell = new HBaseCell();
> resultCell.setFamily(family);
> resultCell.setQualifier(qualifier);
>
> resultCell.setValue(endpoint.getCamelContext().getTypeConverter().convertTo(String.class,
> keyValue.getValue()));
> resultRow.getCells().add(resultCell); //will fail to
> insert if some cell with same Family and Qualifier exists
> }
> ...
> }
> {code}
> that means we can't specify family and qualifier option when consuming.
> # remove option
> the default value of remove option is true, that mean, after scan the table,
> all scanned row will be removed. I think it's not we expect, so user may have
> to add option remove=false to stop that. however this option doesn't describe
> on website http://camel.apache.org/hbase.html .
> Besides these problem, I think some descriptions on
> http://camel.apache.org/hbase.html are not correct, for example the demos and
> Header Options. please have a check.
--
This message was sent by Atlassian JIRA
(v6.2#6252)