mirror of
https://git.pleroma.social/sjw/pleroma-fe.git
synced 2024-12-23 15:25:18 +01:00
add unit test for elimination logic
This commit is contained in:
parent
53c9517a4a
commit
65ef039316
@ -1,7 +1,20 @@
|
||||
import Status from '../status/status.vue'
|
||||
import timelineFetcher from '../../services/timeline_fetcher/timeline_fetcher.service.js'
|
||||
import Conversation from '../conversation/conversation.vue'
|
||||
import { throttle } from 'lodash'
|
||||
import { throttle, keyBy } from 'lodash'
|
||||
|
||||
export const getExcludedStatusIdsByPinning = (statuses, pinnedStatusIds) => {
|
||||
const ids = []
|
||||
if (pinnedStatusIds && pinnedStatusIds.length > 0) {
|
||||
for (let status of statuses) {
|
||||
if (!pinnedStatusIds.includes(status.id)) {
|
||||
break
|
||||
}
|
||||
ids.push(status.id)
|
||||
}
|
||||
}
|
||||
return ids
|
||||
}
|
||||
|
||||
const Timeline = {
|
||||
props: [
|
||||
@ -43,16 +56,9 @@ const Timeline = {
|
||||
},
|
||||
// id map of statuses which need to be hidden in the main list due to pinning logic
|
||||
excludedStatusIdsObject () {
|
||||
const result = {}
|
||||
if (this.pinnedStatusIds && this.pinnedStatusIds.length > 0) {
|
||||
for (let status of this.timeline.visibleStatuses) {
|
||||
if (!this.pinnedStatusIds.includes(status.id)) {
|
||||
break
|
||||
}
|
||||
result[status.id] = true
|
||||
}
|
||||
}
|
||||
return result
|
||||
const ids = getExcludedStatusIdsByPinning(this.timeline.visibleStatuses, this.pinnedStatusIds)
|
||||
// Convert id array to object
|
||||
return keyBy(ids, id => id)
|
||||
}
|
||||
},
|
||||
components: {
|
||||
|
17
test/unit/specs/components/timeline.spec.js
Normal file
17
test/unit/specs/components/timeline.spec.js
Normal file
@ -0,0 +1,17 @@
|
||||
import { getExcludedStatusIdsByPinning } from 'src/components/timeline/timeline.js'
|
||||
import { difference } from 'lodash'
|
||||
|
||||
describe('Timeline', () => {
|
||||
describe('getExcludedStatusIdsByPinning', () => {
|
||||
it('should not return unpinned status ids', () => {
|
||||
const statuses = [
|
||||
{ id: 1 },
|
||||
{ id: 2 },
|
||||
{ id: 3 },
|
||||
{ id: 4 }
|
||||
]
|
||||
const pinnedStatusIds = [1, 3]
|
||||
expect(difference(getExcludedStatusIdsByPinning(statuses, pinnedStatusIds), pinnedStatusIds)).to.eql([])
|
||||
})
|
||||
})
|
||||
})
|
Loading…
Reference in New Issue
Block a user