Shim – a node.js app simplifying Cross Browser/ Device Testing
Shim is a node.js app, created by Chris Marstall of Boston Globe, in order to allow simultaneous, synced web surfing across a variety of devices and browsers. Shim was created as a timesaving way to see how BostonGlobe’s web sites render on a variety of gadgets & browsers. It works by tweaking Wifi to enable the easy synchronization of browsing sessions across several devices, with no client configuration needed.
This makes cross-browser and cross-device testing much simpler. With one click, it's possible to see a page rendered on devices of varying screen size, input technology, etc.
Visualize a group of people browsing using a variety of devices, all connected to a single Wifi access point that's running Shim. Whenever one of them clicks on a link, all the others will be automatically redirected to the linked page.
There is no device-specific configuration required, so even simple gadgets can synchronize. We've tested this so far with iPad, iPhone, Nexus S, Samsung Galaxy Tab, Motorola Xoom, Kindle 3, Barnes & Noble Color Nook, Windows Phone 7 and a variety of desktop browsers, but it should work on most current devices that have a Javascript-enabled web browser.
Chris achieved this by turning on Internet Sharing on a stock Mac Book Pro, then modifying it at the system level to act as a transparent proxy. The laptop intercepts all wifi traffic and redirects it to a custom node.js server, which inserts a javascript "shim" at the head of each web page that is visited. The shim, once loaded in a device's browser, opens and maintains a socket connection to the server. Whenever a new page is requested, the page's url is broadcast to all connected browsers, which then redirect themselves to that url, keeping all devices in sync.
Cinderella - Ultimate development environment for open source hacking on Mac OSX
Cinderella builds everything up in ~/Developer. It won't stomp on any of your current installations so you don't have to commit your entire machine immediately. It's simple to rollback if you really want to.
Various Development environment Cinderella Provides are:
- mysql, postgres, redis, solr, memcached and mongodb
- ruby (1.8.7) via rbenv.
- python (2.7) with pip.
- node.js (0.4.11) with npm.
- erlang (R13B04) environment.
Don't like to miss out any of our posts? Do Subscribe to our Feed
Tags
- Open Source (60)
- JavaScript (57)
- Mobile Web (43)
- HTML 5 (22)
- NoSQL (22)
- jQuery (21)
- Database (19)
- Node.js (17)
- Android (15)
- Conference (14)
- View all 76 tags »
- Presentation Slides (14)
- .Net Framework (12)
- PHP (9)
- CMS (7)
- Presentation Videos (7)
- HeathCare IT (6)
- AMT (6)
- Amazon web services (6)
- MYSQL (6)
- Programming Languages (6)
- Agile (5)
- HTML (5)
- Mobile App Development (5)
- Tutorials (5)
- CSS (4)
- Programming (4)
- UX (4)
- Security (3)
- AMT Quiz (3)
- CSS3 (3)
- GitHub (3)
- Greetings (3)
- HIPAA (3)
- Tools (3)
- iPad Apps (3)
- Ace (2)
- Facebook App Development (2)
- Linux (2)
- Microsoft Silverlight (2)
- Mono (2)
- OSX Development (2)
- PHP Framework (2)
- Python (2)
- Ruby (2)
- Ruby on Rails (2)
- Scrum (2)
- WebRTC (2)
- Windows 7 (2)
- WordPress Framework (2)
- e-Learning (2)
- iOS 5 (2)
- Adobe AIR (1)
- Apache (1)
- BT Summit 2010 (1)
- C++ (1)
- Corporate Storytelling (1)
- Django (1)
- Dojo (1)
- EHR (1)
- EPR (1)
- Electronic Patient Record (1)
- FaceTime (1)
- Flash (1)
- Game Developement (1)
- Lean (1)
- Marketing (1)
- Microsoft (1)
- Mozilla (1)
- Perl (1)
- Product Development (1)
- SCM (1)
- SDT Table Dynamic MySQL PHP (1)
- SEO (1)
- Web Development Framework (1)
- Windows 8 (1)
- iOS Software Development (1)
Get Updates
Get the latest updates in your email box automatically.