POPULARITY
In this episode, Josh and WIll continue the #tedlasso goes to #college series. In this series, they leverage lessons from the show about #leadership, #learning, and #people to glean how we can be better teachers. In this third episode, they are joined by the awesome Robin Jeffers to glean insights about caring for students from the character Rebecca. After that, they discuss Robin's new favorite tool CommonLit.org. For more on our conversation, check out the episode page here. Head over to our website at hitechpod.us for all of our episode pages, send some support at Buy Me a Coffee, our Twitter, our YouTube, our connection to Education Podcast Network, and to see our faces (maybe skip the last one). Start making your podcast on Riverside.fm today using our affiliate sign-up link! --- Send in a voice message: https://podcasters.spotify.com/pod/show/hitechpod/message
Commonlit.org is a free site for educators! Sign up today! We believe in text sets and want you to have access to recommendations we thought would pair perfectly with THE IMPOSSIBLE GIRL by Ashley White. Research shows that students will increase their comprehension when they have access to a variety of texts. We trust the research, and we know it works! Trust us! So, how do you build a text set? You find fiction, nonfiction, poetry, video, images, etc. that build on a central concept, help students compare/contrast, have similar themes, etc. CommonLit is the source that can help you build a text set for Monarch books. We've checked each title and think it's a great match. 1. "The Worst Birthday" from Harry Potter and the Chamber of Secrets (Fiction) 2. Witchcraft in Salem (Nonfiction) 3. The Impossibles (Poetry) 4. Target Lesson: Women Who Speak Up (Nonfiction) 5. Karen Aiach on Doing the Impossible (video link) Buy TIG wherever books are sold! You'll love it! YouTube Video: How to Read The Monarch Way - https://youtu.be/wd9LhqZwUqU Affiliate Amazon Link: https://amzn.to/442Qe4a --- Send in a voice message: https://podcasters.spotify.com/pod/show/monarchbooks/message Support this podcast: https://podcasters.spotify.com/pod/show/monarchbooks/support
In this week's Week in Edtech, Ben and special guest co-host Hailey Carter:1) Talk to Salwa Muhammad of Fourthbrain.ai about the upcoming 3-day workshop with Andrew Ng and other AI Education leaders2) Discuss "Study Hall", new Youtube/ASU/Crash Course Collaboration (Youtube Blog)3) Take note of a recent survey that expresses doubt about Edtech leaders (Edweek)4) Compare Recent Reports on the State of Edtech Funding- Reach Capital (US)- Brighteye Ventures (Europe)- Inc42 (India)5) Explore the Push for the $60K Minimum Teacher Salary in the US (Edweek)6) Look at the Race to Adapt to a ChatGPT World (Forbes, NYTimes) and Quill and CommonLit's Free Tool to Detect Cheating
It's about time for teachers to start their opinion, persuasive, or argumentative writing units (depending on the grade you teach). Most teachers realize that sample sentences and essays are an important component of any writing unit. But, one of the hardest parts about teaching this type of writing is finding writing samples that are age appropriate. It's easy to look on websites of popular newspaper outlets and find an opinion piece, opinion polls, and someone's personal opinion shared via an editorial. The problem is these newspapers have paywalls set up, limiting access. Also, the writing is written at the high school level and much too complex for say, fifth graders. Plus tools like Newsela and CommonLit require payment. But, I'm here to shout from the rooftops that finding a variety of writing samples is easier than ever with a new tool called Chat GPT and right now it's completely free, but it might not be for long! I recently published a three-part series about how Chat GPT, and future iterations of this tool, are going to have a significant impact on the way we teach. This tool is striking fear in the hearts of teachers worried about plagiarism. But, getting stuck in fear is a mistake! English teachers need to take advantage of its ability to generate sentence examples, opinion questions, persuasive writing prompts, and more. Teachers can use this tool to enhance their teaching and save time, and I'm going to prove it to you right here, right now.
Hablamos de demandas, más demandas e inteligencias artificiales.Puedes apoyar la realización de este programa con una suscripción. Más información por acáNoticias -En Estados Unidos, el Departamento de Justicia y 8 estados de la Unión Americana presentaron una demanda en contra de Google, acusándolo de violación a políticas antimonopolio en el mercado publicitario digital. -Los investigadores de la Unión Europea planean abrir una investigación sobre Microsoft Teams para saber si el que este producto esté vinculado a la suite de Office afecta la competencia justa. Esta investigación está basada en una queja hecha por Slack en 2020.-En Alemania el grupo manifestante en contra de discursos de odio, HateAid, y la Unión Europea de Estudiantes Judíos presentaron una demanda en la corte regional de Berlín, argumentando que Twitter no ejerce sus reglas en contra del contenido antisemita, incluyendo a quienes niegan el holocausto. -La plataforma de diseño de Shutterstock, Creative Flow, ahora ofrece un generador de texto a imagen impulsado por Dall-E 2 de OpenAI. -Las organizaciones de escritura sin fines de lucro Quill y CommonLit lanzaron una herramienta llamada AI Writing Check. Análisis: Profesores contra Estudiantes¿Prefieres leer las noticias? ¡Suscríbete a mi newsletter y te llegarán todos los días! Become a member at https://plus.acast.com/s/noticias-de-tecnologia-express. Hosted on Acast. See acast.com/privacy for more information.
When Michelle Brown started her first teaching job at a low income school in Mississippi, she was confronted by the deep inequities in the system and decided to do something about it. Michelle went on to found CommonLit, a non-profit technology company with a mission to close the opportunity gap in education through literacy. Ilham sits down with Michelle to discuss her journey from teacher to tech entrepreneur, and the impact of CommonLit, which is doing so much to improve literacy for students, especially those in low income schools. Time stamps1:32 - Upbringing and inspiration to pursue education3: 32 - First teaching job5:53 - From teacher to tech entrepreneur10:10 - What is CommonLit?14:03 - Impact of CommonLit20:00 - Growth of the program23:33 - Diversity, equity and inclusion 25:48 - What's next? 27:08 - Advice for young entrepreneurs28:13 - Hobbies About Michelle BrownMichelle Brown is the founder and CEO of CommonLit, an innovative and free online educational program that reinvents the way students learn to read. Under Michelle's leadership, CommonLit has grown to over 20 million users and it's having a profound impact on improving literacy across the United States, particularly in low income schools. She is an experienced classroom teacher who has taught in urban and rural environments, and at the university level as a professor of Spanish. For additional details about the podcast, show notes, and access to resources mentioned during the show, please visit https://www.solvay.com/podcast
The following is a conversation between Michelle Brown, founder and CEO of CommonLit, and Denver Frederick, the Host of The Business of Giving. CommonLit is a nonprofit education technology organization dedicated to ensuring that all students, especially those in Title I schools, graduate with the reading, writing, communication, and problem-solving skills they need to be successful in college and beyond. They have been especially busy since the lockdown and are now helping create solutions to address the learning loss that occurred as a result. And here to share that story with us is Michelle Brown, the founder and CEO of CommonLit.
Guest Geoff Harcourt, CTO of CommonLit, joins Joël to talk about a thing that comes up with a lot with clients: the performance of their test suite. It's often a concern because with test suites, until it becomes a problem, people tend to not treat it very well, and people ask for help on making their test suites faster. Geoff shares how he handles a scenario like this at CommonLit. This episode is brought to you by Airbrake (https://airbrake.io/?utm_campaign=Q3_2022%3A%20Bike%20Shed%20Podcast%20Ad&utm_source=Bike%20Shed&utm_medium=website). Visit Frictionless error monitoring and performance insight for your app stack. Geoff Harcourt (https://twitter.com/geoffharcourt) Common Lit (https://www.commonlit.org/) Cuprite driver (https://cuprite.rubycdp.com/) Chrome DevTools Protocol (CDP) (https://chromedevtools.github.io/devtools-protocol/) Factory Doctor (https://test-prof.evilmartians.io/#/profilers/factory_doctor) Joël's RailsConf talk (https://www.youtube.com/watch?v=LOlG4kqfwcg) Formal Methods (https://www.hillelwayne.com/post/formally-modeling-migrations/) Rails multi-database support (https://guides.rubyonrails.org/active_record_multiple_databases.html) Knapsack pro (https://knapsackpro.com/) Prior episode with Eebs (https://www.bikeshed.fm/353) Shopify article on skipping specs (https://shopify.engineering/spark-joy-by-running-fewer-tests) Transcript: JOËL: Hello and welcome to another episode of The Bike Shed, a weekly podcast from your friends at thoughtbot about developing great software. I'm Joël Quenneville. And today, I'm joined by Geoff Harcourt, who is the CTO of CommonLit. GEOFF: Hi, Joël. JOËL: And together, we're here to share a little bit of what we've learned along the way. Geoff, can you briefly tell us what is CommonLit? What do you do? GEOFF: CommonLit is a 501(c)(3) non-profit that delivers a literacy curriculum in English and Spanish to millions of students around the world. Most of our tools are free. So we take a lot of pride in delivering great tools to teachers and students who need them the most. JOËL: And what does your role as CTO look like there? GEOFF: So we have a small engineering team. There are nine of us, and we run a Rails monolith. I'd say a fair amount of the time; I'm hands down in the code. But I also do the things that an engineering head has to do, so working with vendors, and figuring out infrastructure, and hiring, and things like that. JOËL: So that's quite a variety of things that you have to do. What is new in your world? What's something that you've encountered recently that's been fun or interesting? GEOFF: It's the start of the school year in America, so traffic has gone from a very tiny amount over the summer to almost the highest load that we'll encounter all year. So we're at a new hosting provider this fall. So we're watching our infrastructure and keeping an eye on it. The analogy that we've been using to describe this is like when you set up a bunch of plumbing, it looks like it all works, but until you really pump water through it, you don't see if there are any leaks. So things are in good shape right now, but it's a very exciting time of year for us. JOËL: Have you ever done some actual plumbing yourself? GEOFF: I am very, very bad at home repair. But I have fixed a toilet or two. I've installed a water filter but nothing else. What about you? JOËL: I've done a little bit of it when I was younger with my dad. Like, I actually welded copper pipes and that kind of thing. GEOFF: Oh, that's amazing. That's cool. Nice. JOËL: So I've definitely felt that thing where you turn the water source back on, and it's like, huh, let's see, is this joint going to leak, or are we good? GEOFF: Yeah, they don't have CI for plumbing, right? JOËL: [laughs] You know, test it in production, right? GEOFF: Yeah. [laughs] So we're really watching right now traffic starting to rise as students and teachers are coming back. And we're also figuring out all kinds of things that we want to do to do better monitoring of our application, so some of this is watching metrics to see if things happen. But some of this is also doing some simulated user activity after we do deploys. So we're using some automated browsers with Cypress to log into our application and do some user flows, and then report back on the results. JOËL: So is this kind of like a feature test in CI, except that you're running it in production? GEOFF: Yeah. Smoke test is the word that we've settled on for it, but we run it against our production server every time we deploy. And it's a small suite. It's nowhere as big as our big Capybara suite that we run in CI, but we're trying to get feedback in less than six minutes. That's sort of the goal. In addition to running tests, we also take screenshots with a tool called Percy, and that's a visual regression testing tool. So we get to see the screenshots, and if they differ by more than one pixel, we get a ping that lets us know that maybe our CSS has moved around or something like that. JOËL: Has that caught some visual bugs for you? GEOFF: Definitely. The state of CSS at CommonLit was very messy when I arrived, and it's gotten better, but it still definitely needs some love. There are some false positives, but it's been really, really nice to be able to see visual changes on our production pages and then be able to approve them or know that there's something we have to go back and fix. JOËL: I'm curious, for this smoke test suite, how long does it take to run? GEOFF: We run it in parallel. It runs on Buildkite, which is the same tool that we use to orchestrate our CI, and the longest test takes about five minutes. It signs in as a teacher, creates an account. It creates a class; it invites the student to that class. It then logs out, logs in as that student creates the student account, signs in as the student, joins the class. It then assigns a lesson to the student then the student goes and takes the lesson. And then, when the student submits the lesson, then the test is over. And that confirms all of the most critical flows that we would want someone to drop what they were doing if it's broken, you know, account creation, class creation, lesson creation, and students taking a lesson. JOËL: So you're compressing the first few weeks of school into five minutes. GEOFF: Yes. And I pity the school that has thousands of fake teachers, all named Aaron McCarronson at the school. JOËL: [laughs] GEOFF: But we go through and delete that data every once in a while. But we have a marketer who just started at CommonLit maybe a few weeks ago, and she thought that someone was spamming our signup form because she said, "I see hundreds of teachers named Aaron McCarronson in our user list." JOËL: You had to admit that you were the spammer? GEOFF: Yes, I did. [laughs] We now have some controls to filter those people out of reports. But it's always funny when you look at the list, and you see all these fake people there. JOËL: Do you have any rate limiting on your site? GEOFF: Yeah, we do quite a bit of it, actually. Some of it we do through Cloudflare. We have tools that limit a certain flow, like people trying to credential stuffing our password, our user sign-in forms. But we also do some further stuff to prevent people from hitting key endpoints. We use Rack::Attack, which is a really nice framework. Have you had to do that in client work with clients setting that stuff up? JOËL: I've used Rack:Attack before. GEOFF: Yeah, it's got a reasonably nice interface that you can work with. And I always worry about accidentally setting those things up to be too sensitive, and then you get lots of stuff back. One issue that we sometimes find is that lots of kids at the same school are sharing an IP address. So that's not the thing that we want to use for rate limiting. We want to use some other criteria for rate limiting. JOËL: Right, right. Do you ever find that you rate limit your smoke tests? Or have you had to bypass the rate limiting in the smoke tests? GEOFF: Our smoke tests bypass our rate limiting and our bot detection. So they've got some fingerprints they use to bypass that. JOËL: That must have been an interesting day at the office. GEOFF: Yes. [laughter] With all of these things, I think it's a big challenge to figure out, and it's similar when you're making tests for development, how to make tests that are high signal. So if a test is failing really frequently, even if it's testing something that's worthwhile, if people start ignoring it, then it stops having value as a piece of signal. So we've invested a ton of time in making our test suite as reliable as possible, but you sometimes do have these things that just require a change. I've become a really big fan of...there's a Ruby driver for Capybara called Cuprite, and it doesn't control chrome with Chrome Driver or with Selenium. It controls it with the Chrome DevTools protocol, so it's like a direct connection into the browser. And we find that it's very, very fast and very, very reliable. So we saw that our Capybara specs got significantly more reliable when we started using this as our driver. JOËL: Is this because it's not actually moving the mouse around and clicking but instead issuing commands in the background? GEOFF: Yeah. My understanding of this is a little bit hazy. But I think that Selenium and ChromeDriver are communicating over a network pipe, and sometimes that network pipe is a little bit lossy. And so it results in asynchronous commands where maybe you don't get the feedback back after something happens. And CDP is what Chrome's team and I think what Puppeteer uses to control things directly. So it's great. And you can even do things with it. Like, you can simulate different time zone for a user almost natively. You can speed up or slow down the traveling of time and the direction of time in the browser and all kinds of things like that. You can flip it into mobile mode so that the device reports that it's a touch browser, even though it's not. We have a set of mobile specs where we flip it with CDP into mobile mode, and that's been really good too. Do you find when you're doing client work that you have a demand to build mobile-specific specs for system tests? JOËL: Generally not, no. GEOFF: You've managed to escape it. JOËL: For something that's specific to mobile, maybe one or two tests that have a weird interaction that we know is different on mobile. But in general, we're not doing the whole suite under mobile and the whole suite under desktop. GEOFF: When you hand off a project...it's been a while since you and I have worked together. JOËL: For those who don't know, Geoff used to be with us at thoughtbot. We were colleagues. GEOFF: Yeah, for a while. I remember my very first thoughtbot Summer Summit; you gave a really cool lightning talk about Eleanor of Aquitaine. JOËL: [laughs] GEOFF: That was great. So when you're handing a project off to a client after your ending, do you find that there's a transition period where you're educating them about the norms of the test suite before you leave it in their hands? JOËL: It depends a lot on the client. With many clients, we're working alongside an existing dev team. And so it's not so much one big handoff at the end as it is just building that in the day-to-day, making sure that we are integrating with the team from the outset of the engagement. So one thing that does come up a lot with clients is the performance of their test suite. That's often a concern because the test suite until it becomes a problem, people tend to not treat it very well. And by the time that you're bringing on an external consultant to help, generally, that's one of the areas of the code that's been a little bit neglected. And so people ask for help on making their test suite faster. Is that something that you've had to deal with at CommonLit as well? GEOFF: Yeah, that's a great question. We have struggled a lot with the speed that our test suite...the time it takes for our test suite to run. We've done a few things to improve it. The first is that we have quite a bit of caching that we do in our CI suite around dependencies. So gems get cached separately from NPM packages and browser assets. So all three of those things are independently cached. And then, we run our suites in parallel. Our Jest specs get split up into eight containers. Our Ruby non-system tests...I'd like to say unit tests, but we all know that some of those are actually integration tests. JOËL: [laughs] GEOFF: But those tests run in 15 containers, and they start the moment gems are built. So they don't wait for NPM packages. They don't wait for assets. They immediately start going. And then our system specs as soon as the assets are built kick off and start running. And we actually run that in 40 parallel containers so we can get everything finished. So our CI suite can finish...if there are no dependency bumps and no asset bumps, our specs suite you can finish in just under five minutes. But if you add up all of that time, cumulatively, it's something like 75 minutes is the total execution as it goes. Have you tried FactoryDoctor before for speeding up test suites? JOËL: This is the gem from Evil Martians? GEOFF: Yeah, it's part of TestProf, which is their really, really unbelievable toolkit for improving specs, and they have a whole bunch of things. But one of them will tell you how many invocations of FactoryBot factories each factory got. So you can see a user factory was fired 13,000 times in the test suite. It can even do some tagging where it can go in and add metadata to your specs to show which ones might be candidates for optimization. JOËL: I gave a talk at RailsConf this year titled Your Tests Are Making Too Many Database Calls. GEOFF: Nice. JOËL: And one of the things I talked about was creating a lot more data via factories than you think that you are. And I should give a shout-out to FactoryProf for finding those. GEOFF: Yeah, it's kind of a silent killer with the test suite, and you really don't think that you're doing a whole lot with it, and then you see how many associations. How do you fight that tension between creating enough data that things are realistic versus the streamlining of not creating extraneous things or having maybe mystery guests via associations and things like that? JOËL: I try to have my base factories be as minimal as possible. So if there's a line in there that I can remove, and the factory or the model still saves, then it should be removed. Some associations, you can't do that if there's a foreign key constraint, and so then I'll leave it in. But I am a very hardcore minimalist, at least with the base factory. GEOFF: I think that makes a lot of sense. We use foreign keys all over the place because we're always worried about somehow inserting student data that we can't recover with a bug. So we'd rather blow up than think we recorded it. And as a result, sometimes setting up specs for things like a student answering a multiple choice question on a quiz ends up being this sort of if you give a mouse a cookie thing where it's you need the answer options. You need the question. You need the quiz. You need the activity. You need the roster, the students to be in the roster. There has to be a teacher for the roster. It just balloons out because everything has a foreign key. JOËL: The database requires it, but the test doesn't really care. It's just like, give me a student and make it valid. GEOFF: Yes, yeah. And I find that that challenge is really hard. And sometimes, you don't see how hard it is to enforce things like database integrity until you have a lot of concurrency going on in your application. It was a very rude surprise to me to find out that browser requests if you have multiple servers going on might not necessarily be served in the order that they were made. JOËL: [laughs] So you're talking about a scenario where you're running multiple instances of your app. You make two requests from, say, two browser tabs, and somehow they get served from two different instances? GEOFF: Or not even two browser tabs. Imagine you have a situation where you're auto-saving. JOËL: Oooh, background requests. GEOFF: Yeah. So one of the coolest features we have at CommonLit is that students can annotate and highlight a text. And then, the teachers can see the annotations and highlights they've made, and it's actually part of their assignment often to highlight key evidence in a passage. And those things all fire in the background asynchronously so that it doesn't block the student from doing more stuff. But it also means that potentially if they make two changes to a highlight really quickly that they might arrive out of order. So we've had to do some things to make sure that we're receiving in the right order and that we're not blowing away data that was supposed to be there. Just think about in a Heroku environment, for example, which is where we used to be, you'd have four dynos running. If dyno one takes too long to serve the thing for dyno two, request one may finish after request two. That was a very, very rude surprise to learn that the world was not as clean and neat as I thought. JOËL: I've had to do something similar where I'm making a bunch of background requests to a server. And even with a single dyno, it is possible for your request to come back out of order just because of how TCP works. So if it's waiting for a packet and you have two of these requests that went out not too long before each other, there's no guarantee that all the packets for request one come back before all the packets from request two. GEOFF: Yeah, what are the strategies for on the client side for dealing with that kind of out-of-order response? JOËL: Find some way to effectively version the requests that you make. Timestamp is an easy one. Whenever a request comes in, you take the response from the latest timestamp, and that wins out. GEOFF: Yeah, we've started doing some unique IDs. And part of the unique ID is the browser's timestamp. We figure that no one would try to hack themselves and intentionally screw up their own data by submitting out of order. JOËL: Right, right. GEOFF: It's funny how you have to pick something to trust. [laughs] JOËL: I'd imagine, in this case, if somebody did mess around with it, they would really only just be screwing up their own UI. It's not like that's going to then potentially crash the server because of something, and then you've got a potential vector for a denial of service. GEOFF: Yeah, yeah, that's always what we're worried about, and we have to figure out how to trust these sorts of requests as what's a valid thing and what is, as you're saying, is just the user hurting themselves as opposed to hurting someone else's stuff? MID-ROLL AD: Debugging errors can be a developer's worst nightmare...but it doesn't have to be. Airbrake is an award-winning error monitoring, performance, and deployment tracking tool created by developers for developers that can actually help cut your debugging time in half. So why do developers love Airbrake? It has all of the information that web developers need to monitor their application - including error management, performance insights, and deploy tracking! Airbrake's debugging tool catches all of your project errors, intelligently groups them, and points you to the issue in the code so you can quickly fix the bug before customers are impacted. In addition to stellar error monitoring, Airbrake's lightweight APM helps developers to track the performance and availability of their application through metrics like HTTP requests, response times, error occurrences, and user satisfaction. Finally, Airbrake Deploy Tracking helps developers track trends, fix bad deploys, and improve code quality. Since 2008, Airbrake has been a staple in the Ruby community and has grown to cover all major programming languages. Airbrake seamlessly integrates with your favorite apps to include modern features like single sign-on and SDK-based installation. From testing to production, Airbrake notifiers have your back. Your time is valuable, so why waste it combing through logs, waiting for user reports, or retrofitting other tools to monitor your application? You literally have nothing to lose. Head on over to airbrake.io/try/bikeshed to create your FREE developer account today! GEOFF: You were talking about test suites. What are some things that you have found are consistently problems in real-world apps, but they're really, really hard to test in a test suite? JOËL: Difficult to test or difficult to optimize for performance? GEOFF: Maybe difficult to test. JOËL: Third-party integrations. Anything that's over the network that's going to be difficult. Complex interactions that involve some heavy frontend but then also need a lot of backend processing potentially with asynchronous workers or something like that, there are a lot of techniques that we can use to make all those play together, but that means there's a lot of complexity in that test. GEOFF: Yeah, definitely. I've taken a deep interest in what I'm sure there's a better technical term for this, but what I call network hostile environments or bandwidth hostile environments. And we see this a lot with kids. Especially during the pandemic, kids would often be trying to do their assignments from home. And maybe there are five kids in the house, and they're all trying to do their homework at the same time. And they're all sharing a home internet connection. Maybe they're in the basement because they're trying to get some peace and quiet so they can do their assignment or something like that. And maybe they're not strongly connected. And the challenge of dealing with intermittent connectivity is such an interesting problem, very frustrating but very interesting to deal with. JOËL: Have you explored at all the concept of Formal Methods to model or verify situations like that? GEOFF: No, but I'm intrigued. Tell me more. JOËL: I've not tried it myself. But I've read some articles on the topic. Hillel Wayne is a good person to follow for this. GEOFF: Oh yeah. JOËL: But it's really fascinating when you'll see, okay, here are some invariants and things. And then here are some things that you set up some basic properties for a system. And then some of these modeling languages will then poke holes and say, hey, it's possible for this 10-step sequence of events to happen that will then crash your server. Because you didn't think that it's possible for five people to be making concurrent requests, and then one of them fails and retries, whatever the steps are. So it's really good at modeling situations that, as developers, we don't always have great intuition, things like parallelism. GEOFF: Yeah, that sounds so interesting. I'm going to add that to my list of reading for the fall. Once the school year calms down, I feel like I can dig into some technical topics again. I've got this book sitting right next to my desk, Designing Data-Intensive Applications. I saw it referenced somewhere on Twitter, and I did the thing where I got really excited about the book, bought it, and then didn't have time to read it. So it's just sitting there unopened next to my desk, taunting me. JOËL: What's the 30-second spiel for what is a data-intensive app, and why should we design for it differently? GEOFF: You know, that's a great question. I'd probably find out if I'd dug further into the book. JOËL: [laughs] GEOFF: I have found at CommonLit that we...I had a couple of clients at thoughtbot that dealt with data at the scale that we deal with here. And I'm sure there are bigger teams doing, quote, "bigger data" than we're doing. But it really does seem like one of our key challenges is making sure that we just move data around fast enough that nothing becomes a bottleneck. We made a really key optimization in our application last year where we changed the way that we autosave students' answers as they go. And it resulted in a massive increase in throughput for us because we went from trying to store updated versions of the students' final answers to just storing essentially a draft and often storing that draft in local storage in the browser and then updating it on the server when we could. And then, as a result of this, we're making key updates to the table where we store a student's answers much less frequently. And that has a huge impact because, in addition to being one of the biggest tables at CommonLit...it's got almost a billion recorded answers that we've gotten from students over the years. But because we're not writing to it as often, it also means that reads that are made from the table, like when the teacher is getting a report for how the students are doing in a class or when a principal is looking at how a school is doing, now, those queries are seeing less contention from ongoing writes. And so we've seen a nice improvement. JOËL: One strategy I've seen for that sort of problem, especially when you have a very write-heavy table but that also has a different set of users that needs to read from it, is to set up a read replica. So you have your main that is being written to, and then the read replica is used for reports and people who need to look at the data without being in contention with the table being written. GEOFF: Yeah, Rails multi-DB support now that it's native to the framework is excellent. It's so nice to be able to just drop that in and fire it up and have it work. We used to use a solution that Instacart had built. It was great for our needs, but it wasn't native to the framework. So every single time we upgraded Rails, we had to cross our fingers and hope that it didn't, you know, whatever private APIs of ActiveRecord it was using hadn't broken. So now that that stuff, which I think was open sourced from GitHub's multi-database implementation, so now that that's all native in Rails, it's really, really nice to be able to use that. JOËL: So these kinds of database tricks can help make the application much more performant. You'd mentioned earlier that when you were trying to make your test performant that you had introduced parallelism, and I feel like that's maybe a bit of an intimidating thing for a lot of people. How would you go about converting a test suite that's just vanilla RSpec, single-threaded, and then moving it in a direction of being more parallel? GEOFF: There's a really, really nice tool called Knapsack, which has a free version. But the pro version, I feel like if you're spending any money at all on CI, it's immediately worth the cost. I think it's something like $75 a month for each suite that you run on it. And Knapsack does this dynamic allocation of tests across containers. And it interfaces with several of the popular CI providers so that it looks at environment variables and can tell how many containers you're splitting across. It'll do some things, like if some of your containers start early and some of them start late, it will distribute the work so that they all end at the same time, which is really nice. We've preferred CI providers that charge by the minute. So rather than just paying for a service that we might not be using, we've used services like Semaphore, and right now, we're on Buildkite, which charge by the minute, which means that you can decide to do as much parallelism as you want. You're just paying for the compute time as you run things. JOËL: So that would mean that two minutes of sequential build time costs just the same as splitting it up in parallel and doing two simultaneous minutes of build time. GEOFF: Yeah, that is almost true. There's a little bit of setup time when a container spins up. And that's one of the key things that we optimize. I guess if we ran 200 containers if we were like Shopify or something like that, we could technically make our CI suite finish faster, but it might cost us three times as much. Because if it takes a container 30 seconds to spin up and to get ready, that's 30 seconds of dead time when you're not testing, but you're paying for the compute. So that's one of the key optimizations that we make is figuring out how many containers do we need to finish fast when we're not just blowing time on starting and finishing? JOËL: Right, because there is a startup cost for each container. GEOFF: Yeah, and during the work day when our engineers are working along, we spin up 200 EC2 machines or 150 EC2 machines, and they're there in the fleet, and they're ready to go to run CI jobs for us. But if you don't have enough machines, then you have jobs that sit around waiting to start, that sort of thing. So there's definitely a tension between figuring out how much parallelism you're going to do. But I feel like to start; you could always break your test suite into four pieces or two pieces and just see if you get some benefit to running a smaller number of tests in parallel. JOËL: So, manually splitting up the test suite. GEOFF: No, no, using something like Knapsack Pro where you're feeding it the suite, and then it's dividing up the tests for you. I think manually splitting up the suite is probably not a good practice overall because I'm guessing you'll probably spend more engineering time on fiddling with which tests go where such that it wouldn't be cost-effective. JOËL: So I've spent a lot of time recently working to improve a parallel test suite. And one of the big problems that you have is trying to make sure that all of your parallel surfaces are being used efficiently, so you have to split the work evenly. So if you said you have 70 minutes worth of work, if you give 50 minutes to one worker and 20 minutes to the other, that means that your total test suite is still 50 minutes, and that's not good. So ideally, you split it as evenly as possible. So I think there are three evolutionary steps on the path here. So you start off, and you're going to manually split things out. So you're going to say our biggest chunk of tests by time are the feature specs. We'll make them almost like a separate suite. Then we'll make the models and controllers and views their own thing, and that's roughly half and half, and run those. And maybe you're off by a little bit, but it's still better than putting them all in one. It becomes difficult, though, to balance all of these because then one might get significantly longer than the other then, you have to manually rebalance it. It works okay if you're only splitting it among two workers. But if you're having to split it among 4, 8, 16, and more, it's not manageable to do this, at least not by hand. If you want to get fancy, you can try to automate that process and record a timing file of how long every file takes. And then when you kick off the build process, look at that timing file and say, okay, we have 70 minutes, and then we'll just split the file so that we have roughly 70 divided by number of workers' files or minutes of work in each process. And that's what gems like parallel_tests do. And Knapsack's Classic mode works like this as well. That's decently good. But the problem is you're working off of past information. And so if the test has changed or just if it's highly variable, you might not get a balanced set of workers. And as you mentioned, there's a startup cost, and so not all of your workers boot up at the same time. And so you might still have a very uneven amount of work done by each worker by statically determining the work to be done via a timing file. So the third evolution here is a dynamic or a self-balancing approach where you just put all of the tests or the files in a queue and then just have every worker pull one or two tests when it's ready to work. So that way, if something takes a lot longer than expected, well, it's just not pulling more from the queue. And everybody else still pulls, and they end up all balancing each other out. And then ideally, every worker finishes work at exactly the same time. And that's how you know you got the most value you could out of your parallel processes. GEOFF: Yeah, there's something about watching all the jobs finish in almost exactly, you know, within 10 seconds of each other. It just feels very, very satisfying. I think in addition to getting this dynamic splitting where you're getting either per file or per example split across to get things finishing at the same time, we've really valued getting fast feedback. So I mentioned before that our Jest specs start the moment NPM packages get built. So as soon as there's JavaScripts that can be executed in test, those kick-off. As soon as our gems are ready, the RSpec non-system tests go off, and they start running specs immediately. So we get that really, really fast feedback. Unfortunately, the browser tests take the longest because they have to wait for the most setup. They have the most dependencies. And then they also run the slowest because they run in the browser and everything. But I think when things are really well-oiled, you watch all of those containers end at roughly the same time, and it feels very satisfying. JOËL: So, a few weeks ago, on an episode of The Bike Shed, I talked with Eebs Kobeissi about dependency graphs and how I'm super excited about it. And I think I see a dependency graph in what you're describing here in that some things only depend on the gem file, and so they can start working. But other things also depend on the NPM packages. And so your build pipeline is not one linear process or one linear process that forks into other linear processes; it's actually a dependency graph. GEOFF: That is very true. And the CI tool we used to use called Semaphore actually does a nice job of drawing the dependency graph between all of your steps. Buildkite does not have that, but we do have a bunch of steps that have to wait for other steps to finish. And we do it in our wiki. On our repo, we do have a diagram of how all of this works. We found that one of the things that was most wasteful for us in CI was rebuilding gems, reinstalling NPM packages (We use Yarn but same thing.), and then rebuilding browser assets. So at the very start of every CI run, we build hashes of a bunch of files in the repository. And then, we use those hashes to name Docker images that contain the outputs of those files so that we are able to skip huge parts of our CI suite if things have already happened. So I'll give an example if Ruby gems have not changed, which we would know by the Gemfile.lock not having changed, then we know that we can reuse a previously built gems image that has the gems that just gets melted in, same thing with yarn.lock. If yarn.lock hasn't changed, then we don't have to build NPM packages. We know that that already exists somewhere in our Docker registry. In addition to skipping steps by not redoing work, we also have started to experiment...actually, in response to a comment that Chris Toomey made in a prior Bike Shed episode, we've started to experiment with skipping irrelevant steps. So I'll give an example of this if no Ruby files have changed in our repository, we don't run our RSpec unit tests. We just know that those are valid. There's nothing that needs to be rerun. Similarly, if no JavaScript has changed, we don't run our Jest tests because we assume that everything is good. We don't lint our views with erb-lint if our view files haven't changed. We don't lint our factories if the model or the database hasn't changed. So we've got all these things to skip key types of processing. I always try to err on the side of not having a false pass. So I'm sure we could shave this even tighter and do even less work and sometimes finish the build even faster. But I don't want to ever have a thing where the build passes and we get false confidence. JOËL: Right. Right. So you're using a heuristic that eliminates the really obvious tests that don't need to be run but the ones that maybe are a little bit more borderline, you keep them in. Shaving two seconds is not worth missing a failure. GEOFF: Yeah. And I've read things about big enterprises doing very sophisticated versions of this where they're guessing at which CI specs might be most relevant and things like that. We're nowhere near that level of sophistication right now. But I do think that once you get your test suite parallelized and you're not doing wasted work in the form of rebuilding dependencies or rebuilding assets that don't need to be rebuilt, there is some maybe not low, maybe medium hanging fruit that you can use to get some extra oomph out of your test suite. JOËL: I really like that you brought up this idea of infrastructure and skipping. I think in my own way of thinking about improving test suites, there are three broad categories of approaches you can take. One variable you get to work with is that total number of time single-threaded, so you mentioned 70 minutes. You can make that 70 minutes shorter by avoiding database writes where you don't need them, all the common tricks that we would do to actually change the test themselves. Then we can change...as another variable; we get to work with parallelism, we talked about that. And then finally, there's all that other stuff that's not actually executing RSpec like you said, loading the gems, installing NPM packages, Docker images. All of those, if we can skip work running migrations, setting up a database, if there are situations where we can improve the speed there, that also improves the total time. GEOFF: Yeah, there are so many little things that you can pick at to...like, one of the slowest things for us is Elasticsearch. And so we really try to limit the number of specs that use Elasticsearch if we can. You actually have to opt-in to using Elasticsearch on a spec, or else we silently mock and disable all of the things that happen there. When you're looking at that first variable that you were talking about, just sort of the overall time, beyond using FactoryDoctor and FactoryProf, is there anything else that you've used to just identify the most egregious offenders in a test suite and then figure out if they're worth it? JOËL: One thing you can do is hook into Active Support notification to try to find database writes. And so you can find, oh, here's where all of the...this test is making way too many database writes for some reason, or it's making a lot, maybe I should take a look at it; it's a hotspot. GEOFF: Oh, that's really nice. There's one that I've always found is like a big offender, which is people doing negative expectations in system specs. JOËL: Oh, for their Capybara wait time. GEOFF: Yeah. So there's a really cool gem, and the name of it is eluding me right now. But there's a gem that raises a special exception if Capybara waits the full time for something to happen. So it lets you know that those things exist. And so we've done a lot of like hunting for...Knapsack will report the slowest examples in your test suite. So we've done some stuff to look for the slowest files and then look to see if there are examples of these negative expectations that are waiting 10 seconds or waiting 8 seconds before they fail. JOËL: Right. Some files are slow, but they're slow for a reason. Like, a feature spec is going to be much slower than a model test. But the model tests might be very wasteful and because you have so many of them, if you're doing the same pattern in a bunch of them or if it's a factory that's reused across a lot of them, then a small fix there can have some pretty big ripple effects. GEOFF: Yeah, I think that's true. Have you ever done any evaluation of test suite to see what files or examples you could throw away? JOËL: Not holistically. I think it's more on an ad hoc basis. You find a place, and you're like, oh, these tests we probably don't need them. We can throw them out. I have found dead tests, tests that are not executed but still committed to the repo. GEOFF: [laughs] JOËL: It's just like, hey, I'm going to get a lot of red in my diff today. GEOFF: That always feels good to have that diff-y check-in, and it's 250 lines or 1,000 lines of red and 1 line of green. JOËL: So that's been a pretty good overview of a lot of different areas related to performance and infrastructure around tests. Thank you so much, Geoff, for joining us today on The Bike Shed to talk about your experience at CommonLit doing this. Do you have any final words for our listeners? GEOFF: Yeah. CommonLit is hiring a senior full-stack engineer, so if you'd like to work on Rails and TypeScript in a place with a great test suite and a great team. I've been here for five years, and it's a really, really excellent place to work. And also, it's been really a pleasure to catch up with you again, Joël. JOËL: And, Geoff, where can people find you online? GEOFF: I'm Geoff with a G, G-E-O-F-F Harcourt, @geoffharcourt. And that's my name on Twitter, and it's my name on GitHub, so you can find me there. JOËL: And we'll make sure to include a link to your Twitter profile in the show notes. The show notes for this episode can be found at bikeshed.fm. This show is produced and edited by Mandy Moore. If you enjoyed listening, one really easy way to support the show is to leave us a quick rating or even a review in iTunes. It really helps other folks find the show. If you have any feedback, you can reach us at @_bikeshed or reach me at @joelquen on Twitter or at hosts@bikeshed.fm via email. Thank you so much for listening to The Bike Shed, and we'll see you next week. Byeeeeeee!!!!!! ANNOUNCER: This podcast was brought to you by thoughtbot. thoughtbot is your expert design and development partner. Let's make your product and team a success.
When a student or audience member has a question, repeating it before you answer allows everyone else to hear it and gives you a chance to clarify the questioner's intent. ---------- You can find full written versions of these tips at cultofpedagogy.com/edutips. ------------------- Thanks to CommonLit for sponsoring this episode. -------------------
Liisa has worked in B-20 education since 1993, as a teacher, state DOE director, leadership coach, and for education nonprofits. She's currently the Director of Curriculum and Instruction for CommonLit. Her older son is her econ/excel tutor and her younger son is her troubleshooter for all things technical. Liisa lives in Olympia, Washington and spends non-school & non-work time consuming pop culture or being the stereotypical PNW outside person. She's excited about hearing about everyone in the cohort, and is on "team original Vandy design."
Leading Improvements in Higher Education with Stephen Hundley
This episode features the co-editors of a special issue of Research & Practice in Assessment focused on the topic of assessment's evolving professional identity. Our guests are Jeanne Horst and Gina Polychronopoulos. Jeanne is Director of Research at CommonLit, and Gina is Associate Director for Curricular Assessment at George Mason University. Our conversation has relevance for both individuals working directly in assessment and for colleagues who support and champion assessment in their respective contexts. Listeners may access the special issue of Research & Practice in Assessment (Volume 17, Issue 2) discussed during this episode by visiting https://www.rpajournal.com/rpa-archives/.This season of Leading Improvements in Higher Education is sponsored by the Center for Assessment and Research Studies at James Madison University; learn more at jmu.edu/assessment.Episode recorded: March 2022. Host: Stephen Hundley. Producers: Chad Beckner, Caleb Keith, and Shirley Yorger. Original music: Caleb Keith. This award-winning podcast is a service of the Assessment Institute in Indianapolis; learn more at assessmentinstitute.iupui.edu.
Former teacher Michelle Brown is on a mission to improve reading and writing skills for children around the globe. That's why she created CommonLit, an education technology non-profit that has grown to reach 80,000 schools in the United States and over 20,000,000 users worldwide.
Former teacher Michelle Brown is on a mission to improve reading and writing skills for children around the globe. That's why she created CommonLit, an education technology non-profit that has grown to reach 80,000 schools in the United States and over 20,000,000 users worldwide.
How is the anti-CRT movement harming and silencing teachers, what damage will it ultimately do to students, and what can be done to fight it? For a more complete overview of this topic, be sure to check out EdTrust's podcast series EdTrusted: The Critical Race Theory Craze That's Sweeping the Nation. ------------------- Thanks to CommonLit and Brain Power Academy for sponsoring this episode. -------------------
Planning instructional units can be less than exciting when all you have to deal with is words and more words. Creating a vision board at the beginning of a unit can generate fresh enthusiasm and help you focus on what truly matters. In this episode, teachers Amanda Cardenas and Marie Morris share how vision boards work in their classrooms. ------------------- Thanks to CommonLit and fastIEP for sponsoring this episode. -------------------
Teachers are saying this is the worst school year ever. In this episode, I'll explore the reasons why, offer some solutions, and also share a few other loosely related thoughts that may or may not help. ------------------- Thanks to CommonLit and Brain Power Academy for sponsoring this episode. -------------------
Many well-intended efforts to make schools more equitable often fail because we're trying to make them work inside a system that's a terrible fit for them. What's been missing is a whole-school approach that creates a path forward that is radically different from what we've done before. In this episode, I talk with the authors of the book Street Data—Shane Safir and Jamila Dugan—about their ground-up approach to school transformation, one that lets go of the fixation on text scores and centers marginalized voices instead. ------------------- Thanks to CommonLit and ISTE for sponsoring this episode. ------------------- Find Shane and Jamila online at shanesafir.com and jamiladugan.com.
Hold on tight because we are sailing into the uncharted waters of Esports in schools this week. Thankfully, we have an expert at the helm, Jesse Lubinsky from Ready Learner One, who is going to navigate us safely through these stormy seas! Here are some links for what we talked about... News & follow-up: Screencastify's new FREE features! CommonLit 360 Curriculum New Apple devices Design your own custom themes in new Google Sites New Google Tasks logo!! Forms settings are now easier to navigate Main Course: Esports with Jesse Lubinsky Chance the Rapper on SNL Tweet from Mike Washburn The Esports Education Playbook: Empowering Every Learner Through Inclusive Gaming (book) readylearner.one jesselubinsky.com Tech Nuggets Live Text in iOS 15 Wheel of Names | Random name picker via Tony Vincent PackBack Webinar Series: Four Tenets of Blended and Personalized Learning Sesame Street Fighter You can follow Jonathan (@jonathanwylie) and Mindy (@TeamCairney) on Twitter, and see all the tweets from the Grant Wood AEA Digital Learning Team at @DLGWAEA. You can also email us with questions or ideas, podcast@gwaea.org. If you enjoy the show please share it with your friends and colleagues and/or leave us a review on your podcast app of choice. THANK YOU for listening. We really couldn't (or wouldn't) do this without the support of listeners like you!
Drew Perkins talks with Michelle Brown, Founder and CEO of CommonLit, about teaching of reading and other literacy skills and how CommonLit can help. Links & Resources Mentioned In This Episode: CommonLit.org @CommonLit @MichelleEileen @ReadingShanahan The TeachThought Podcast Ep. 197 Are We Teaching Reading Wrong By Omitting Knowledge? Visit wegrowteachers.com for more info on our workshops and services.
In this episode of The Suite Talk, Scott will go over blooket.com for gamifying your classroom, grade transferer for making workflow much easier from Google Classroom to your school platform (I.e- Genesis) and CommonLit for ELA classrooms providing close reading of an incredibly diverse library. You can check out my website www.thesuitetalk.com for more information about my show. Want to be a guest? Please do so and show off your edtech expertise! Please click here or visit my website to fill out the guest form. I will get back to you as soon as I can. Stay up to date on the latest episode on my YouTube channel, newsletter or podcast. My show is available on Podbean, Spotify, Apple Podcasts, and Google Podcast. Click on the ‘Episodes' page to read the show notes and watch past or current episodes. Check out the schedule of upcoming guests. Need a white board? I would recommend trying Jamboard. Check out my Jamboard page. My Get on the Jamboard Train presentation an article I wrote for Equip Magazine, How to use Jamboard for Digital Learning Success My Ideaboard for Jamboard resource My Wakelet collection on Jamboard Alice Keeler and I wrote a new book called Stepping up to Google Classroom. It has 50 steps to help beginners get started, plus many tips and pedagogy that will help you re-think your classroom workflow and mindset. The book is available for order on Amazon. Thank you for your support!
April 2 2021 - Episode 43The Ignite EdTech Podcast with @mrkempnz1. Introduction 2. Question for you - How do you ensure that it is learning first, technology second in your setting? 3. EdTech Tool of the Week - CommonLit4. EdTech Tip of the Week - Google Tips and Tricks5. Interview with Stacey Roshan and Al Kingsley6. Win this weeks prize (merchandise from Al Kingsley and Net Support) by going to bit.ly/edtechwin and completing the short form (Competition ends 9am SGT on Wednesday 7 April).7. Subscribe, Rate and ShareIf you have a question that you want answered on the podcast please emailinfo@igniteedtech.comConnect with Mark Quinn here or via email markquinn9129@gmail.com - Make a Difference Podcast (Mark Quinn)Links from PodcastIgnite EdTech Learning Portal (Learning Courses for everyone - Sign up for FREE today to join the biggest and fastest growing EdTech community online!)Stacey Roshan on TwitterStacey's BookStacey's Website Educational Duct Tape PodcastAl Kingsley on TwitterAl's Website and PodcastThe Blended Learning WorkbookSylvia Duckworth - SketchnotingMicrosoft Office LensNet Support
En esta doceava sesión nos acompaña José Antonio Morfin Rojas de la Universidad Iberoamericana; Alejandro Ordóñez Torres de la Universidad Panamericana y Pedro Jacinto Páramo Kañetas de la Universidad del Valle de México así como la moderadora Gema Jara Arancibia de Commonlit Español.
Clases y talleres virtuales que ofrecen contenidos en formato manos a la obra, para capacitarte en Educación STEAM, empleos de futuro e innovación con visión social incluyente y así impactar en tu entorno.
¿Cómo es la Educación STEAM y el desarrollo de habilidades socioemocionales? Checa este Panel de Expertos con Creativa Kids, Commonlit, Colegio Startford y la Escuela Thomás Alva Edison. Panelistas: Colegio Stratford | Dir. Carlos Cabrera Rodríguez, Director General Commonlit | Dra. Gema Jara Arancibia, Directora General de Proyectos Commonlit Español Creativa Kids | Arq. Alejandro Suárez Bautista, Director General Escuela Thomás Alva Edison | Eduardo Chávez Hernández, Head of IT Fundación RobotiX | Roberto Saint Martin, Director General Moderadora Marlene Gras Marín | Consultora Independiente y Asesora de Programas Educativos Globales de la la Organización Techint ¡Mantente al tanto de todo lo que tenemos para ti en nuestras redes sociales! #MovimientoSTEAM #STEAM
Welcome to another episode of Develomentor. Today's guest is Geoffrey Harcourt. Geoff Harcourt is the CTO at CommonLit, a non-profit that provides reading curriculum services in English and Spanish to students and teachers around the world. CommonLit currently serves over 15 million students between the 3rd and 12th grades. Before joining CommonLit he was a product engineering consultant at thoughtbot, where he worked with high-growth startups to help them tackle process and scaling problems. He previously worked as CTO of Cortex Building Intelligence, a startup whose product helps commercial real estate operators reduce their utility use. Geoff began his career working in several product-side roles and transitioned to engineering after learning how to code on nights and weekends. He majored in history in college.Click Here –> For more information about tech careersEpisode Summary“I want to work with people that are relentlessly curious. They don’t have to be a total expert at Ruby or Rails or PostgreSQL or the core technologies we use at CommonLit. But if I feel 6 months from now, their skillset will be even bigger than it was before, I think they can be a really good fit working with us.““I was a consultant sort of acting like a fill-in technical cofounder for startups that didn’t have a technical cofounder.““For me to learn a technical concept, I have to use it in a project I care about the results of.“—Geoff HarcourtIn this episode we’ll cover:What is it like working for an education nonprofit, CommonLit? What does Geoff look for when building his team as CTO?What did Geoff do after graduating with a history degree from Harvard?Why project-based learning is so important for Geoff in acquiring new skills?How Geoff got introduced to coding by running a website for his fantasy baseball league?Check out Geoffrey's startup Cortexintel - https://get.cortexintel.com/Learn more about CommonLit - https://www.commonlit.org/unsupported_browser.htmlLearn more about thoughtbot - https://thoughtbot.com/You can find more resources in the show notesTo learn more about our podcast go to https://develomentor.com/To listen to previous episodes go to https://develomentor.com/blog/Follow Geoff HarcourtTwitter: @geoffharcourtLinkedIn: linkedin.com/in/geoffharcourt/Follow Develomentor:Twitter: @develomentorFollow Grant IngersollTwitter: @gsingersLinkedIn: linkedin.com/in/grantingersoll
We discuss the Coronavirus from the perspective of a new college student, student teacher, looking for jobs, and working in a school district. Then we think about how this pandemic might bring change to the education system. Maybe the answer is to remove subject silos and integrate learning using Newsela and CommonLit. Our biggest breakthrough is that we may be able to literally solve the world’s problems from home using PBL and the UN’s Sustainable Development Goals. Enjoy!
Typically on the podcast, I interview one EdTech entrepreneur, often a founder or CEO or an accomplished professional in the industry. Today's episode is a little different. After doing the show for a year, I've started to notice some trends in the stories and insights that founders share. So today is the first example of me reporting on one of those trends, and it comes in the form of sharing three excerpts of past episodes. I'm going to share with you a clip from my conversation with Michelle Brown, the founder of CommonLit. A clip from my conversation with Brett Kopf, who along with his brother created Remind and also a clip from my conversation with Brad Schiller, who is the CEO of Prompt In each of these clips, you'll hear the three entrepreneurs discuss what I'm calling their Superhero Origin Stories. We all know how before superheroes get their powers or when they discover their powers, they go through some kind of formative story. And I've noticed that for many EdTech founders, something similar happens. I hope you enjoy this new format for this podcast, and please give me your feedback about whether you like it or not. You can do that on Twitter @GerardDawson3 or you can connect and message me on LinkedIn, and I'm Gerard Dawson there. Also, if you liked the episode, please give the podcast a rating. Leave a review on iTunes, and be sure to share it with the entrepreneur or educator in your life. Thanks for listening, Gerard Dawson https://www.GerardDawson.com
Tim Lorenzen, a 6th grade teacher at Las Sendas Elementary, shares his experience with technology in his classroom throughout his lengthy teaching career. Starting out with no technology to today, Tim is able to differentiate his ELA lessons as students develop their writing process skills with technology. Lorenzen shares how he plans and develops his technology enabled lessons to meet the needs of his diverse learners and provide immediate feedback. Show Notes ReadWorks.org Commonlit.org 21st Century Skills Blended Learning in the Classroom
Michlle Brown knows that a teacher's favorite word is...free! Today, Michelle and I discuss the powerful CommonLit platform, the free service offering teachers thousands of texts, at different levels, to help engage students and boost their literacy skills.
Mrs. Gallina reads an article from CommonLit for Intensive Reading students
Michelle Brown: Founder of CommonLit by GroundBreakers
In this episode, Michelle Brown (EdM, 2014) describes her journey from Harvard to founding an award-winning, nonprofit education technology company that is dedicated to improving adolescent literacy rates. Learn more at commonlit.org. (And PS, they're hiring! Head on over to their Career page to browse through their exciting opportunities). Interviewer: Vanessa E. Beary, President Release Date: December 21, 2017
The #CommonLitCraze continues!After having some technical trouble initiating an interview with CommonLit.org content development director Anna Hodges, we decided to break into two episodes our podcast on this quickly-rising-in-popularity ELA-centered website. And it was worth it because one week could not give CommonLit all the credit it's due.In this episode, Anna discusses all teachers need to know about getting started with CommonLit in the ELA classroom. Check out the show notes here: http://acrossthehall.edublogs.org/2017/08/02/ath-3-commonlit-craze-part-two/
The #CommonLitCraze continues!After having some technical trouble initiating an interview with CommonLit.org content development director Anna Hodges, we decided to break into two episodes our podcast on this quickly-rising-in-popularity ELA-centered website. And it was worth it because one week could not give CommonLit all the credit it's due.In this episode, Anna discusses all teachers need to know about getting started with CommonLit in the ELA classroom. Check out the show notes here: http://acrossthehall.edublogs.org/2017/08/02/ath-3-commonlit-craze-part-two/
The CommonLit Craze starts here.If you've not heard of or used CommonLit yet, you can't pass up this episode! With a huge selection of grade-appropriate texts and questions to help students master every literary standard, CommonLit, a free resource for teachers, is becoming every teacher's best friend for differentiating assignments based on reading level, skill-based need, and student interest.Listen as Cade and Michelle discuss key features and suggested how-tos of CommonLit in the classroom!Check out the show notes here: http://acrossthehall.edublogs.org/2017/07/22/episode-2-commonlit-craze/
The CommonLit Craze starts here.If you've not heard of or used CommonLit yet, you can't pass up this episode! With a huge selection of grade-appropriate texts and questions to help students master every literary standard, CommonLit, a free resource for teachers, is becoming every teacher's best friend for differentiating assignments based on reading level, skill-based need, and student interest.Listen as Cade and Michelle discuss key features and suggested how-tos of CommonLit in the classroom!Check out the show notes here: http://acrossthehall.edublogs.org/2017/07/22/episode-2-commonlit-craze/
CommonLit with Sarah Mielbye | EdTech Innovators & Innovations by EdTech Times
If you're always looking for short, high-quality informational and literary texts to use in your classroom, you are going to love the free online library at CommonLit. In this episode, I interview CommonLit founder Michelle Brown to talk about why she started the platform and walk through all of the wonderful features that help teachers get the most out of this growing library of texts.
