I understand you were using a thinly traded contract and that certainly would cause the onBarUpdates to be issued irregularly.
Please keep in mind you are dealing with COBC=true and the Close time of the bar, not that it is being processed at 10 PM. The Day bar only has one time which is the end of the bar.
Thanks for clarifying your coding. Here is a code snippet using BarsInProgress that would help simplify your coding:
if(BarsInProgress == 1) Print("Day bars " + Time[0]);
if(BarsInProgress == 2) Print("Minute bars " + Time[0]);
Please let me know if I can be of further assistance.
Comment