verdict-project/verdict

Creating empty scramble should throw exception

Opened this issue · 6 comments

When a scramble is created on a empty data set I think it should throw an error to avoid broken scrambles. (I tried to append to the scramble later).

Here is a example I got from a scramble on a empty table:

{"schemaName":"verdict_scrambles","tableName":"my_table","originalSchemaName":"default","originalTableName":"my_table","aggregationBlockColumn":"verdictdbblock","aggregationBlockCount":1,"tierColumn":"verdictdbtier","numberOfTiers":1,"method":"UNIFORM","scramblingMethod":{"blockSize":1000000,"type":"uniform","maxBlockCount":100,"relativeSize":0.1,"storedProbDist":{"0":["Infinity"]},"MAIN_TABLE_SOURCE_ALIAS":"t","totalNumberOfblocks":0,"actualNumberOfBlocks":1,"mainTableAlias":"t","tierCount":1,"blockCount":0,"actualBlockCount":1},"hashColumn":null,"cumulativeDistributions":{"0":["Infinity"]}}
"cumulativeDistributions":{"0":["Infinity"]}
"storedProbDist":{"0":["Infinity"]}

I'm sorry that no one has been following up with this issue.

@dongyoungy Can you take a look into this? The fix seems to be pretty straightforward.

I have already asked Jiacheng to look at an efficient way of determining an empty table to solve this issue.

I see. That's great.

No worries, thank you!

Hi, I have created a pull request to solve this problem. In the process of creating scramble, it will throw a VerdictDBException when empty table is detected.

@commercial-hippie FYI, the fix for this issue has been merged into master.