From b0f89401ff864ec06f31a3bddcde0d75de3611d7 Mon Sep 17 00:00:00 2001 From: hogashi Date: Mon, 9 Jan 2023 19:36:17 +0900 Subject: [PATCH 1/3] migrate to MV3 --- dist/manifest.json | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/dist/manifest.json b/dist/manifest.json index d6b2c848..d08ba163 100644 --- a/dist/manifest.json +++ b/dist/manifest.json @@ -1,7 +1,7 @@ { - "manifest_version": 2, + "manifest_version": 3, "name": "twitter画像原寸ボタン", - "version": "4.2.0", + "version": "5.0.0", "description": "twitterの画像ツイートにボタンを追加する拡張機能。追加されたボタンを押すとツイートの画像を原寸で新しいタブに表示する。連絡先: @hogextend", "author": "hogashi", "permissions": ["tabs", "storage"], @@ -22,10 +22,9 @@ } ], "background": { - "scripts": ["js/background.bundle.js"], - "persistent": false + "service_worker": "js/background.bundle.js" }, - "browser_action": { + "action": { "default_icon": "icons/icon.png", "default_title": "twitter画像原寸ボタン", "default_popup": "html/popup.html" From 6a8ed536619c91efadeb6133c99ae992936f04c7 Mon Sep 17 00:00:00 2001 From: hogashi Date: Sun, 5 Feb 2023 00:31:07 +0900 Subject: [PATCH 2/3] remove migration code --- __tests__/options.test.js | 40 ++++--------------------------- coverage/badge.svg | 2 +- src/extension-contexts/options.ts | 40 ++++--------------------------- 3 files changed, 11 insertions(+), 71 deletions(-) diff --git a/__tests__/options.test.js b/__tests__/options.test.js index 6f3320fa..930877c9 100644 --- a/__tests__/options.test.js +++ b/__tests__/options.test.js @@ -1,13 +1,5 @@ import { chrome } from 'jest-chrome'; -import { - initialOptions, - initialOptionsBool, - isFalse, - MIGRATED_TO_CHROME_STORAGE, - SHOW_ON_TWEETDECK_TIMELINE, - SHOW_ON_TIMELINE, - SHOW_ON_TWEETDECK_TWEET_DETAIL, -} from '../src/constants'; +import { initialOptionsBool, SHOW_ON_TIMELINE, SHOW_ON_TWEETDECK_TWEET_DETAIL } from '../src/constants'; import { getOptions, setOptions } from '../src/extension-contexts/options'; @@ -24,44 +16,22 @@ chrome.storage.sync.get.mockImplementation((keys, callback) => { }); beforeEach(() => { chromeStorage = {}; - localStorage.clear(); }); describe('options', () => { describe('getOptions', () => { - it('何もない状態で呼んだら, 初期値が返って, 初期値が保存されて, 移行済みになる', () => { + it('chrome.storageが空の状態で呼んだら, 初期値が返る (chrome.storageは空のまま)', () => { expect(getOptions()).resolves.toMatchObject(initialOptionsBool); - expect(chromeStorage).toMatchObject({ - ...initialOptionsBool, - [MIGRATED_TO_CHROME_STORAGE]: true, - }); - }); - it('未移行で, localStorageに設定があったら, localStorageの内容が移行されつつ返って, 移行済みになる', () => { - Object.entries({ ...initialOptions, [SHOW_ON_TWEETDECK_TIMELINE]: isFalse }).map(([k, v]) => { - localStorage.setItem(k, v); - }); - const expected = { ...initialOptionsBool, [SHOW_ON_TWEETDECK_TIMELINE]: false }; - expect(getOptions()).resolves.toMatchObject(expected); - expect(chromeStorage).toMatchObject({ - ...expected, - [MIGRATED_TO_CHROME_STORAGE]: true, - }); + expect(chromeStorage).toMatchObject({}); }); - it('移行済みなら, 保存された設定が返る', () => { - Object.entries({ ...initialOptions, [SHOW_ON_TWEETDECK_TIMELINE]: isFalse }).map(([k, v]) => { - localStorage.setItem(k, v); - }); + it('chrome.storageに保存された設定があるなら, それが返る', () => { chromeStorage = { ...initialOptionsBool, [SHOW_ON_TIMELINE]: false, - [MIGRATED_TO_CHROME_STORAGE]: true, }; const expected = { ...initialOptionsBool, [SHOW_ON_TIMELINE]: false }; expect(getOptions()).resolves.toMatchObject(expected); - expect(chromeStorage).toMatchObject({ - ...expected, - [MIGRATED_TO_CHROME_STORAGE]: true, - }); + expect(chromeStorage).toMatchObject(expected); }); }); describe('setOptions', () => { diff --git a/coverage/badge.svg b/coverage/badge.svg index fdcac574..c88ab65e 100644 --- a/coverage/badge.svg +++ b/coverage/badge.svg @@ -1 +1 @@ -Coverage: 82.58%Coverage82.58% \ No newline at end of file +Coverage: 82.46%Coverage82.46% \ No newline at end of file diff --git a/src/extension-contexts/options.ts b/src/extension-contexts/options.ts index 6a967228..446ef7a0 100644 --- a/src/extension-contexts/options.ts +++ b/src/extension-contexts/options.ts @@ -1,11 +1,4 @@ -import { - OptionsBool, - initialOptions, - initialOptionsBool, - OPTION_KEYS, - isTrue, - MIGRATED_TO_CHROME_STORAGE, -} from '../constants'; +import { OptionsBool, initialOptionsBool, OPTION_KEYS } from '../constants'; export const setOptions = (options: OptionsBool): void => { chrome.storage.sync.set(options, () => { @@ -14,33 +7,10 @@ export const setOptions = (options: OptionsBool): void => { }; export const getOptions = (): Promise => { - return new Promise((resolve) => { - // chrome.storageから取ってきつつ, - // まだ移行してないときはlocalStorageあるいは初期値を移行 - chrome.storage.sync.get(MIGRATED_TO_CHROME_STORAGE, (isMigrated) => { - if (!isMigrated[MIGRATED_TO_CHROME_STORAGE]) { - const newOptions = { ...initialOptions, ...localStorage }; - // 真偽値にして移行する - const newOptionsBool = { ...initialOptionsBool }; - OPTION_KEYS.forEach((key) => { - newOptionsBool[key] = newOptions[key] === isTrue; - }); - chrome.storage.sync.set( - { - ...newOptionsBool, - [MIGRATED_TO_CHROME_STORAGE]: true, - }, - () => { - // 移行できたら新しい値を返す - resolve(newOptionsBool); - }, - ); - } else { - chrome.storage.sync.get(OPTION_KEYS, (got) => { - // 初期値をフォールバックとしておく - resolve({ ...initialOptionsBool, ...got }); - }); - } + return new Promise(resolve => { + chrome.storage.sync.get(OPTION_KEYS, got => { + // 初期値をフォールバックとしておく + resolve({ ...initialOptionsBool, ...got }); }); }); }; From 03ec02701c2f6afcf396d7a779e213361020924d Mon Sep 17 00:00:00 2001 From: hogashi Date: Sun, 5 Feb 2023 00:38:53 +0900 Subject: [PATCH 3/3] call callback function on mocked set --- __tests__/options.test.js | 3 ++- coverage/badge.svg | 2 +- 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/__tests__/options.test.js b/__tests__/options.test.js index 930877c9..81b18f05 100644 --- a/__tests__/options.test.js +++ b/__tests__/options.test.js @@ -4,8 +4,9 @@ import { initialOptionsBool, SHOW_ON_TIMELINE, SHOW_ON_TWEETDECK_TWEET_DETAIL } import { getOptions, setOptions } from '../src/extension-contexts/options'; let chromeStorage = {}; -chrome.storage.sync.set.mockImplementation((items) => { +chrome.storage.sync.set.mockImplementation((items, callback) => { chromeStorage = { ...chromeStorage, ...items }; + callback(); }); chrome.storage.sync.get.mockImplementation((keys, callback) => { if (typeof keys === 'string') { diff --git a/coverage/badge.svg b/coverage/badge.svg index c88ab65e..561215b8 100644 --- a/coverage/badge.svg +++ b/coverage/badge.svg @@ -1 +1 @@ -Coverage: 82.46%Coverage82.46% \ No newline at end of file +Coverage: 82.76%Coverage82.76% \ No newline at end of file