Comments (6)
browserInfo
is mainly used for logging browser runtime information. The setPuppeteerConfig
is an internal API used by MemLab core to set the puppeteer information used by the logger.
If you would like to set the executable binary of the browser, consider using the --chromium-binary
CLI argument:
memlab run --scenario scenario.js --chromium-binary <path to Chrome binary>
from memlab.
Thank you for the quick reply. I tried your suggestion and this did actually make memlab use my normal chrome instead of chromium, but there is still one issue. I would expect the chrome instance to keep me logged in to my website, but it doesn't. In fact, it looks like a clean version of chrome where I'm not logged in and no addons are installed etc. I expected this to use my "normal" chrome.
Here is the exact command I used:
memlab run --scenario .\libs\shared\memlab\scenario.js --headful --chromium-binary "C:\Program Files\Google\Chrome\Application\chrome.exe"
from memlab.
To have chrome logged in, you can define the cookies
callback in the scenario file:
https://facebook.github.io/memlab/docs/api/interfaces/core_src.IScenario/#optional-cookies
from memlab.
In the example code I provided the cookies callback is set. I can confirm that I see the cookies applied correctly by looking at my Devtools > Application > Cookies. The name and value is set correctly. The only difference I see between the cookies is that my normal chrome instance has HttpOnly set to true, Secure set to true and SameSite set to None, whereas the memlab instance of chrome doesn't have a value set for any of the above mentioned properties. I can add some screenshots to compare the two cookies.
Do you know of a way for me to set those properties to match my normal chrome version of cookies?
from memlab.
Can you try adding httpOnly: true
to the argument passed to the cookies
callback?
const scenario = {
...
cookies: () => [
{name:'cookie_name', value: 'cookie_value', httpOnly: true, domain: ...},
...
],
};
from memlab.
This actually worked! I never thought to try this because of the documentation for the Cookies type defined here
https://github.com/facebook/memlab/blob/fdac330/packages/core/src/lib/Types.ts#L189
from memlab.
Related Issues (20)
- Can't switch chrome version HOT 2
- Idea - Question - Discussion - Using memlab to refactor code targeting different framework philosphy HOT 1
- Question - How does it pull memory information ? HOT 1
- 老哥有点问题,本地默认安装你的仓库里面有个依赖包引入 colors 的包默认是1.4.2的 被污染的那个包 导致 启动不起来,windows 开发环境, HOT 2
- Question: Any idea about ignoring weak reference and circular reference in heap snapshot? HOT 7
- takeHeapSnapshot timed out HOT 10
- core_1.browserInfo.setPuppeteerConfig is not a function HOT 2
- Is there a way to run in scripting mode using silent? HOT 4
- Could not find Chrome (ver. 121.0.6167.85). This can occur if either 1. you did not perform an installation before running the script (e.g. `npx puppeteer browsers install chrome`) or 2. your cache path is incorrectly configured HOT 3
- Could not find Chrome (ver. 121.0.6167.85). This can occur if either 1. you did not perform an installation before running the script (e.g. `npx puppeteer browsers install chrome`) or 2. your cache path is incorrectly configured
- Keep `@memlab/*` versions in lockstep in package.json HOT 1
- how to handle Page crashed error ,when execute the run method。 HOT 1
- how to get leak info from memlab console HOT 6
- Clarify the documentation about measure mode HOT 3
- Using a basic `retainerReferenceFilter` causes Node OOM exception HOT 7
- Add ESM support for @memlab/api (and remaining) HOT 4
- Puppeteer browser.close() hangs on AWS Lambda HOT 2
- TypeError: core_1.utils.tryToMutePuppeteerWarning is not a function HOT 2
- Error occurs when executing scenarios involving dialog display HOT 1
- Need guidance on accessing elements in code using heap object ID HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from memlab.