-
Notifications
You must be signed in to change notification settings - Fork 45
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
We'll say that an item is only removed if it (1) has an "in_source" annotation and it is false. This annotation should always be present for metrics, but is not currently set for any other object.
- Loading branch information
Showing
7 changed files
with
46 additions
and
28 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,6 +1,6 @@ | ||
import { isExpired } from "./metrics"; | ||
import { isExpired, isRemoved } from "./items"; | ||
|
||
export const filterUncollectedItems = (items, showUncollected) => | ||
items.filter( | ||
(item) => showUncollected || (!isExpired(item.expires) && item.in_source) | ||
(item) => showUncollected || (!isExpired(item) && !isRemoved(item)) | ||
); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,12 @@ | ||
export const isRemoved = (item) => { | ||
// only consider an item expired if it has an in_source property | ||
// and it is false | ||
return item.in_source === false; | ||
}; | ||
|
||
export const isExpired = (item) => { | ||
if (item.expires === "never" || item.expires === undefined) { | ||
return false; | ||
} | ||
return new Date() > new Date(item.expires); | ||
}; |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
import { isExpired, isRemoved } from "../src/state/items"; | ||
|
||
describe("checking if a date has expired", () => { | ||
it("returns True if input is 'never' or undefined", () => { | ||
expect(isExpired({ expires: "never" }) || isExpired({})).toEqual(false); | ||
}); | ||
it("returns True if input is a date from the past", () => { | ||
expect(isExpired({ expires: "2021-01-01" })).toEqual(true); | ||
}); | ||
it("returns False if input is a date from the future", () => { | ||
expect(isExpired({ expires: "3021-01-01" })).toEqual(false); | ||
}); | ||
}); | ||
|
||
describe("isRemoved works as expected", () => { | ||
it("returns true if in_source is false", () => { | ||
expect(isRemoved({ in_source: false })).toEqual(true); | ||
}); | ||
it("returns false if in_source is undefined", () => { | ||
expect(isRemoved({})).toEqual(false); | ||
}); | ||
it("returns false if in_source is true", () => { | ||
expect(isRemoved({ in_source: true })).toEqual(false); | ||
}); | ||
}); |
This file was deleted.
Oops, something went wrong.