Feature #3944
closedOmitted FreshnessPeriod implies always stale
100%
Description
In Content Store, treat a Data without FreshnessPeriod as FreshnessPeriod=0ms (always stale) rather than FreshnessPeriod=infinity (always fresh).
       Updated by Junxiao Shi over 8 years ago
      Updated by Junxiao Shi over 8 years ago
      
    
    - Blocked by Feature #2440: Omitted FreshnessPeriod implies always stale added
       Updated by Junxiao Shi over 8 years ago
      Updated by Junxiao Shi over 8 years ago
      
    
    The current implementation (omitted FreshnessPeriod means infinity) appears to have an effective FreshnessPeriod of 99999ms.
In nfd::cs::Entry::updateStaleTime() function, I added:
std::cout << this->getName() << ' ' << time::steady_clock::now() << ' ' << m_staleTime << '\n';
And I got:
/A/5 0 nanoseconds since unit test clock advancements 99999000000 nanoseconds since unit test clock advancements
/A/5 203850304910641 nanoseconds since boot 203950303908994 nanoseconds since boot
However, setting FreshnessPeriod to an explicit value greater than 99999ms works correctly.
       Updated by Junxiao Shi over 8 years ago
      Updated by Junxiao Shi over 8 years ago
      
    
    - Assignee set to Eric Newberry
- Target version set to v0.6
- Estimated time changed from 1.50 h to 3.00 h
All invocations of getFreshnessPeriod should be inspected. Some components in addition to CS have conditionals related to omitted FreshnessPeriod.
       Updated by Eric Newberry over 8 years ago
      Updated by Eric Newberry over 8 years ago
      
    
    - Status changed from New to In Progress
       Updated by Eric Newberry over 8 years ago
      Updated by Eric Newberry over 8 years ago
      
    
    Junxiao Shi wrote:
The current implementation (omitted FreshnessPeriod means infinity) appears to have an effective FreshnessPeriod of 99999ms.
Innfd::cs::Entry::updateStaleTime()function, I added:std::cout << this->getName() << ' ' << time::steady_clock::now() << ' ' << m_staleTime << '\n';And I got:
/A/5 0 nanoseconds since unit test clock advancements 99999000000 nanoseconds since unit test clock advancements /A/5 203850304910641 nanoseconds since boot 203950303908994 nanoseconds since bootHowever, setting FreshnessPeriod to an explicit value greater than 99999ms works correctly.
It looks like the CS unit test fixture was setting the FreshnessPeriod of stored data to 99999ms by default. I removed this.
       Updated by Eric Newberry over 8 years ago
      Updated by Eric Newberry over 8 years ago
      
    
    - Status changed from In Progress to Code review
- % Done changed from 0 to 100
       Updated by Eric Newberry over 8 years ago
      Updated by Eric Newberry over 8 years ago
      
    
    https://gerrit.named-data.net/#/c/3883 to ndn-cxx causes unit test failures in ndn-tools and possibly other projects.
       Updated by Eric Newberry over 8 years ago
      Updated by Eric Newberry over 8 years ago
      
    
    The issues in ndn-tools mentioned in note 7 should be fixed in the new patchset posted for ndn-cxx and with the new change pushed for ndn-tools (https://gerrit.named-data.net/#/c/3899/).
       Updated by Eric Newberry over 8 years ago
      Updated by Eric Newberry over 8 years ago
      
    
    - Status changed from Code review to Closed
       Updated by Junxiao Shi over 8 years ago
      Updated by Junxiao Shi over 8 years ago
      
    
    - Status changed from Closed to Resolved
There's a mistake in merged code, causing default-constructed Selectors to be non-empty.
I fixed it in https://gerrit.named-data.net/3998.
       Updated by Davide Pesavento over 8 years ago
      Updated by Davide Pesavento over 8 years ago
      
    
    - Status changed from Resolved to Closed