Skip to content
This repository has been archived by the owner on Dec 11, 2019. It is now read-only.

Commit

Permalink
Update getDetailFromTab to consider pinnedLocation
Browse files Browse the repository at this point in the history
also normalize site key without trailing slash

fix #10241

Auditors: @bsclifton, @bbondy

Test Plan:
1. Go to feedly.com
2. Pin the tab
3. Bookmark it and change the location to https://feedly.com
4. Unpin the pinned tab
5. Relaunch Brave
6. There shouldn't be any pinned tab
  • Loading branch information
darkdh authored and bsclifton committed Aug 7, 2017
1 parent 9203d68 commit 64b156b
Show file tree
Hide file tree
Showing 6 changed files with 175 additions and 36 deletions.
14 changes: 12 additions & 2 deletions app/renderer/reducers/frameReducer.js
Original file line number Diff line number Diff line change
Expand Up @@ -100,7 +100,12 @@ const frameReducer = (state, action, immutableAction) => {
const pinned = immutableAction.getIn(['changeInfo', 'pinned'])
if (pinned != null) {
if (pinned) {
state = state.setIn(['frames', index, 'pinnedLocation'], tab.get('url'))
const history = state.getIn(['frames', index, 'history'])
if (history && history.size !== 0) {
state = state.setIn(['frames', index, 'pinnedLocation'], history.first())
} else {
state = state.setIn(['frames', index, 'pinnedLocation'], tab.get('url'))
}
} else {
state = state.deleteIn(['frames', index, 'pinnedLocation'])
}
Expand All @@ -110,7 +115,12 @@ const frameReducer = (state, action, immutableAction) => {
if (url != null && tab.get('pinned') === true) {
const pinnedLocation = state.getIn(['frames', index, 'pinnedLocation'])
if (!pinnedLocation || pinnedLocation === 'about:blank' || pinnedLocation === '') {
state = state.setIn(['frames', index, 'pinnedLocation'], tab.get('url'))
const history = state.getIn(['frames', index, 'history'])
if (history && history.size !== 0) {
state = state.setIn(['frames', index, 'pinnedLocation'], history.first())
} else {
state = state.setIn(['frames', index, 'pinnedLocation'], tab.get('url'))
}
}
}

Expand Down
12 changes: 12 additions & 0 deletions app/sessionStore.js
Original file line number Diff line number Diff line change
Expand Up @@ -513,6 +513,18 @@ module.exports.runPostMigrations = (data) => {
data.sites = sites
}

// sites trailing slash migration
if (typeof data.sites === 'object') {
for (let key in data.sites) {
if (/.+|\d+|\d+/.test(key)) {
const site = data.sites[key]
const newKey = siteUtil.getSiteKey(Immutable.fromJS(site))
data.sites[newKey] = site
delete data.sites[key]
}
}
}

return data
}

Expand Down
20 changes: 20 additions & 0 deletions js/state/siteUtil.js
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,9 @@ module.exports.getSiteKey = function (siteDetail) {
return folderId.toString()
} else if (location) {
location = UrlUtil.getLocationIfPDF(location)
if (location && location[location.length - 1] === '/') {
location = location.slice(0, -1)
}
return location + '|' +
(siteDetail.get('partitionNumber') || 0) + '|' +
(siteDetail.get('parentFolderId') || 0)
Expand Down Expand Up @@ -589,6 +592,23 @@ module.exports.getDetailFromTab = function (tab, tag, sites) {
}
}

if (results.size === 0 && tag === siteTags.PINNED) {
let pinnedLocation = tab.getIn(['frame', 'pinnedLocation'])
if (!pinnedLocation) {
const history = tab.getIn(['frame', 'history'])
if (history && history.size !== 0) {
pinnedLocation = history.first()
}
}
if (pinnedLocation && pinnedLocation !== location) {
siteKey = module.exports.getSiteKey(makeImmutable({
location: pinnedLocation,
partitionNumber
}))
results = results.merge(getSitesBySubkey(sites, siteKey, tag))
}
}

// update details which get returned below
if (results.size > 0) {
location = results.getIn([0, 'location'])
Expand Down
4 changes: 2 additions & 2 deletions test/unit/app/common/state/siteCacheTest.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,8 @@ const assert = require('assert')
const Immutable = require('immutable')

describe('siteCache', function () {
const testUrl1 = 'https://brave.com/'
const testUrl2 = 'http://example.com/'
const testUrl1 = 'https://brave.com'
const testUrl2 = 'http://example.com'
const bookmark = Immutable.fromJS({
lastAccessedTime: 123,
objectId: [210, 115, 31, 176, 57, 212, 167, 120, 104, 88, 88, 27, 141, 36, 235, 226],
Expand Down
23 changes: 23 additions & 0 deletions test/unit/app/sessionStoreTest.js
Original file line number Diff line number Diff line change
Expand Up @@ -911,4 +911,27 @@ describe('sessionStore unit tests', function () {
}
})
})

describe('runPostMigrations', function () {
it('sites trailing slash migration', function () {
const data = {
sites: {
'https://brave.com/|0|0': {
location: 'https://brave.com/',
partitionNumber: 0
}
}
}
const expectedResult = {
sites: {
'https://brave.com|0|0': {
location: 'https://brave.com/',
partitionNumber: 0
}
}
}
const result = sessionStore.runPostMigrations(data)
assert.deepEqual(result, expectedResult)
})
})
})
Loading

0 comments on commit 64b156b

Please sign in to comment.